Packages

library(tidyverse)
library(ggrepel)
library(extraDistr)   # install.packages("extraDistr")
library(HDInterval)   # install.packages("HDAPerval")
library(tidybayes)    # install.packages("tidybayes")
library(bayesplot)    # install.packages("bayesplot")
library(modelr)
library(broom.mixed)  # install.packages("broom.mixed")
library(brms)         # install.packages("brms")
library(ggthemes)
library(patchwork)
library(ggokabeito)   # install.packages("ggokabeito")
theme_set(theme_minimal())

# Creating a theme function used for visualizations
theme_clean <- function() {
  theme_minimal(base_family = "Arial") +
    theme(panel.grid.minor = element_blank(),
          plot.title = element_text(face = "bold"),
          axis.title = element_text(face = "bold"),
          strip.text = element_text(face = "bold", size = rel(1), hjust = 0),
          strip.background = element_rect(fill = "grey80", color = NA),
          legend.title = element_text(face = "bold"))
}

Loading the models

model_Int <- base::readRDS(file = "Models/brms_Int.rds")
model_Nat <- base::readRDS(file = "Models/brms_Nat.rds")
model_articRate <- base::readRDS(file = "Models/brms_articRate.rds")
model_AAVS <- base::readRDS(file = "Models/brms_AAVS.rds")
model_M1s <- base::readRDS(file = "Models/brms_M1s.rds")
model_M1sh <- base::readRDS(file = "Models/brms_M1sh.rds")
model_M2s <- base::readRDS(file = "Models/brms_M2s.rds")
model_M2sh <- base::readRDS(file = "Models/brms_M2sh.rds")

Formatting info

textSize_plotTitle <- 9
textSize_plotSubtitle <- 9
textSize_axisTitle <- 9

01. Reliability

workingData_Int <- base::readRDS(file = "workingData/data_Int.RDS")
workingData_Nat <- base::readRDS(file = "workingData/data_Nat.RDS")

interRel_plotData <- rbind(
  workingData_Int$data %>%
    dplyr::select(c(
      gorilla_id,
      speaker_id,
      `Time Point` = time_point,
      Group = group,
      Sex = sex,
      age,
      rating
    )
    ) %>%
    dplyr::mutate(
      Measure = "Intelligibility"
    ),
  workingData_Nat$data %>%
    dplyr::select(c(
      gorilla_id,
      speaker_id,
      `Time Point` = time_point,
      Group = group,
      Sex = sex,
      age,
      rating
    )
    ) %>%
    dplyr::mutate(
      Measure = "Naturalness"
    )
) %>%
  dplyr::filter(gorilla_id != "10237851") %>%
  dplyr::group_by(speaker_id, `Time Point`, Group, Sex, age, Measure) %>%
  dplyr::summarise(M = mean(rating),
                   sd = sd(rating)) %>%
  dplyr::ungroup() %>%
  dplyr::mutate(`Time Point` = factor(`Time Point`,
                                      levels = c("before",
                                                 "sensors",
                                                 "after"),
                                      labels = c("Before Sensors",
                                                 "With Sensors",
                                                 "After Sensors")),
                Measure = factor(Measure,
                                 levels = c("Intelligibility",
                                            "Naturalness"),
                                 labels = c("Intelligibility Ratings",
                                            "Naturalness Ratings")),
                Group = factor(Group,
                               levels = c("Control",
                                          "PD"),
                               labels = c("Control",
                                          "PwPD")))
`summarise()` has grouped output by 'speaker_id', 'Time Point', 'Group', 'Sex', 'age'. You can override using the `.groups` argument.
interRel_plot <- interRel_plotData %>%
  ggplot() +
  aes(
    x = M,
    y = sd,
    color = Group,
    shape = `Time Point`
  ) +
  geom_point() +
  facet_wrap(~Measure) +
  labs(x = "Average Rating (Mean)",
       y = "Rating Variability (sd)",
       title = "Inter-listener Reliability",
       #subtitle = "The mean and standard deviation of ratings across speakers and time points."
       ) +
  ggokabeito::scale_color_okabe_ito(order = c(2,
                                             #5,
                                             #4,
                                             1)) +
  ggthemes::theme_clean() &
  theme(
    strip.text.x = element_text(hjust = 0, size = 12),
    strip.text.y = element_text(angle = 0),
    plot.background = element_blank(),
    #panel.margin=unit(.05, "lines"),
        panel.border = element_rect(color = "black", fill = NA, size = 1), 
        strip.background = element_rect(color = "black", size = 1),
    #panel.border = element_rect(color = "black", fill = NA, size = 1), 
    legend.position = "bottom",
    legend.box="vertical",
    legend.background = element_rect(color = NA),
    aspect.ratio = 1)
Warning: The `size` argument of `element_rect()` is deprecated as of ggplot2 3.4.0.
Please use the `linewidth` argument instead.
interRel_plot

ggsave(plot = interRel_plot,
       file = "Figures/Fig_Inter-Listener Reliability.png",
       height = 5,
       width = 6.5,
       units = "in",
       scale = 1,
       bg = "white")

02. Artic Rate

Expected Posteriors

# Generate expected predictions from the posterior
data_posterior_articRate <- model_articRate %>%
  tidybayes::epred_draws(
    newdata = tidyr::expand_grid(
      group = c("Control", "PD"),
      time_point = c("before", "sensors", "after"),
      sex = c("Male", "Female"),
      age = 66.88,
    ),
    re_formula = NA
  ) %>%
  group_by(.draw, group, time_point) %>%
  summarize(.epred = mean(.epred), .groups = "drop") %>%
  dplyr::mutate(
    group = factor(
      group,
      levels = c("Control", "PD"),
      labels = c("Control", "PwPD")
    ),
    #grouping = paste(sex, group, sep = " - "),
    #grouping = factor(grouping,
    #                  levels = c("Male - Control",
    #                             "Male - PwPD",
    #                             "Female - Control",
    #                             "Female - PwPD")),
    time_point = factor(
      time_point,
      levels = c("before", "sensors", "after"),
      labels = c("Before\nSensors", "With\nSensors", "After\nSensors")
    )
  )

plot_grandMean_articRate <- ggplot(data_posterior_articRate, 
                                   aes(x = .epred, y = time_point, fill = group)) +
  stat_halfeye(alpha = .9) +
  ggokabeito::scale_fill_okabe_ito(order = c(2, 1)) +
  labs(x = "Predicted articulation rate (syl/s)", y = NULL,
       fill = "Group",
       title = "(a) Posterior Predictions",
       subtitle = "Predicted articulation rate after\ncontrolling for speaker age and sex.") +
  scale_y_discrete(limits = rev) +
  theme_clean() +
  #facet_grid(sex~.) +
  theme(legend.position = "bottom",
        axis.title = element_text(size = textSize_axisTitle),
        plot.title = element_text(size = textSize_plotTitle),
        plot.subtitle = element_text(size = textSize_plotSubtitle),
        #panel.border = element_rect(color = "grey", fill = NA)
        ) +
  guides(fill = guide_legend(nrow = 1))

ME: Timepoint x Group

robust_articRate <- rio::import("workingData/data_articRate.RDS")$pairwise %>%
  dplyr::select(contrast, group, robust)
Warning: Missing `trust` will be set to FALSE by default for RDS in 2.0.0.
data_meContrasts_articRate <- model_articRate %>%
  emmeans::emmeans( ~ time_point | group, epred = TRUE, re_formula = NA, ) %>%
  emmeans::contrast(method = "revpairwise") %>%
  gather_emmeans_draws() %>%
  dplyr::filter(contrast != "after - sensors")

# Compute the interaction contrast (difference in contrasts between groups)
interaction_contrast <- model_articRate %>%
  emmeans::emmeans( ~ time_point * group, epred = TRUE, re_formula = NA) %>%
  emmeans::contrast(interaction = "revpairwise") %>%
  gather_emmeans_draws() %>%
  dplyr::rename(contrast = time_point_revpairwise, group = group_revpairwise) %>%
  dplyr::filter(contrast != "after - sensors")

data_meContrasts_articRate <- base::rbind(data_meContrasts_articRate, interaction_contrast) %>%
  dplyr::mutate(group = case_when(
    group == "PD" ~ "PwPD",
    group == "Control" ~ "Control",
    group == "PD - Control" ~ "PwPD -\nControl"
  )) %>%
  base::merge(., robust_articRate)

plot_RQ1_articRate <- ggplot(
  data_meContrasts_articRate %>%
    dplyr::filter(contrast == "sensors - before"),
    aes(x = .value, y = group, fill = robust)
) +
  geom_vline(xintercept = 0, alpha = .3) +
  stat_halfeye(alpha = .9) +
  scale_fill_manual(values = c("#E3B5CF", "#CC79A7"),
                     drop = FALSE) +
  labs(
    x = "Average marginal effect of sensors effects (syl/s)",
    y = NULL,
    title = "(b) Research Question 1",
    subtitle = "Sensor effect (With Sensors - Before Sensors)\nper group and the effect contrast between groups.",
    fill = "Robust at 95% HPD Interval & pd"
  ) +
  scale_y_discrete(limits = rev) +
  theme_clean() +
  theme(
    legend.position = "bottom",
    axis.title = element_text(size = textSize_axisTitle),
    plot.title = element_text(size = textSize_plotTitle),
    plot.subtitle = element_text(size = textSize_plotSubtitle)
  )

plot_RQ1_articRate


plot_RQ2_articRate <- ggplot(
  data_meContrasts_articRate %>%
    dplyr::filter(contrast == "after - before"),
    aes(x = .value, y = group, fill = robust)
) +
  geom_vline(xintercept = 0, alpha = .3) +
  stat_halfeye(alpha = .9) +
  scale_fill_manual(values = c("#E3B5CF", "#CC79A7"),
                     drop = FALSE) +
  labs(
    x = "Average marginal effect of after-sensor\neffects (syl/s)",
    y = NULL,
    title = "(c) Research Question 2",
    subtitle = "After-sensor effect (After Sensors -\nBefore Sensors) per group and the\neffect contrast between groups.",
    fill = "Robust at 95% HPD Interval & pd"
  ) +
  scale_y_discrete(limits = rev) +
  theme_clean() +
  theme(
    legend.position = "bottom",
    axis.title = element_text(size = textSize_axisTitle),
    plot.title = element_text(size = textSize_plotTitle),
    plot.subtitle = element_text(size = textSize_plotSubtitle)
  )

plot_RQ2_articRate


# Combined plot
plot_articRate <-  plot_grandMean_articRate + plot_RQ1_articRate + plot_RQ2_articRate +
  patchwork::plot_layout(ncol = 3, heights = c(1), guides = "collect"
                         ) +
  plot_annotation(title = "Articulation Rate", #subtitle = "Predicted intelligibility ratings across group/severity and speaking conditions.",
                  theme = theme_clean()) &
  theme(legend.position = "bottom")
plot_articRate

ggsave(
  plot = plot_articRate,
  filename = "Figures/Fig_articRate.png",
  height = 6,
  width = 10,
  unit = "in",
  scale = .9,
  bg = "white"
)

03. AAVS

Expected Posteriors

# Generate expected predictions from the posterior
data_posterior_AAVS <- model_AAVS %>%
  tidybayes::epred_draws(
    newdata = tidyr::expand_grid(
      group = c("Control", "PD"),
      time_point = c("before", "sensors", "after"),
      sex = c("Male", "Female"),
      age = mean(model_AAVS$data$age),
      artic_rate = mean(model_AAVS$data$artic_rate),
    ),
    re_formula = NA
  ) %>%
  group_by(.draw, group, time_point) %>%
  summarize(.epred = mean(.epred), .groups = "drop") %>%
  dplyr::mutate(
    group = factor(
      group,
      levels = c("Control", "PD"),
      labels = c("Control", "PwPD")
    ),
    #grouping = paste(sex, group, sep = " - "),
    #grouping = factor(grouping,
    #                  levels = c("Male - Control",
    #                             "Male - PwPD",
    #                             "Female - Control",
    #                             "Female - PwPD")),
    time_point = factor(
      time_point,
      levels = c("before", "sensors", "after"),
      labels = c("Before\nSensors", "With\nSensors", "After\nSensors")
    )
  )

plot_grandMean_AAVS <- ggplot(data_posterior_AAVS, aes(x = .epred, y = time_point, fill = group)) +
  stat_halfeye(alpha = .9) +
  ggokabeito::scale_fill_okabe_ito(order = c(2, 1)) +
  labs(x = "Predicted AAVS (mel²)", y = NULL,
       fill = "Group",
       title = "(a) Posterior Predictions",
       subtitle = "Predicted AAVS after controlling for\nspeaker age, sex, and articulation rate.") +
  scale_y_discrete(limits = rev) +
  #coord_cartesian(xlim = c(.65,1)) +
  theme_clean() +
  #facet_grid(sex~.) +
  theme(legend.position = "bottom",
        axis.title = element_text(size = textSize_axisTitle),
        plot.title = element_text(size = textSize_plotTitle),
        plot.subtitle = element_text(size = textSize_plotSubtitle),
        #panel.border = element_rect(color = "grey", fill = NA)
        ) +
  guides(fill = guide_legend(nrow = 1))
plot_grandMean_AAVS

ME: Timepoint x Group

robust_AAVS <- rio::import("workingData/data_AAVS.RDS")$pairwise %>%
  dplyr::select(contrast, group, robust)
Warning: Missing `trust` will be set to FALSE by default for RDS in 2.0.0.
data_meContrasts_AAVS <- model_AAVS %>%
  emmeans::emmeans(~ time_point | group,
                   epred = TRUE,
                   re_formula = NA,) %>%
  emmeans::contrast(method = "revpairwise") %>%
  gather_emmeans_draws() %>%
  dplyr::filter(contrast != "after - sensors")  %>%
  dplyr::mutate(group = case_when(
      group == "PD" ~ "PwPD",
      group == "Control" ~ "Control"
    ))

# Compute the interaction contrast (difference in contrasts between groups)
interaction_contrast <- model_AAVS %>%
  emmeans::emmeans(~ time_point * group, epred = TRUE, re_formula = NA) %>%
  emmeans::contrast(interaction = "revpairwise") %>%
  gather_emmeans_draws() %>%
  dplyr::rename(contrast = time_point_revpairwise,
                group = group_revpairwise) %>%
  dplyr::filter(contrast != "after - sensors")  %>%
  dplyr::mutate(group = case_when(
      group == "PD - Control" ~ "PwPD -\nControl"
    ))

data_meContrasts_AAVS <- base::rbind(data_meContrasts_AAVS, interaction_contrast) %>%
  base::merge(., robust_AAVS) %>%
  dplyr::mutate(
    robust = factor(robust, levels = c("not robust", "robust")))

#bayestestR::p_direction(data_meContrasts_AAVS)

plot_RQ1_AAVS <- ggplot(
  data_meContrasts_AAVS %>%
    dplyr::filter(contrast == "sensors - before"),
  aes(x = .value, y = group, fill = robust)
) +
  geom_vline(xintercept = 0, alpha = .3) +
  stat_halfeye(alpha = .9) +
  scale_fill_manual(values = c("#E3B5CF", "#CC79A7"),
                     drop = FALSE) +
  labs(
    x = "Average marginal effect of sensors effects (mel²)",
    y = NULL,
    title = "(b) Research Question 1",
    subtitle = "Sensor effect (With Sensors - Before Sensors)\nper group and the effect contrast between groups.",
    fill = "Robust at 95% HPD Interval & pd"
  ) +
  scale_y_discrete(limits = rev) +
  theme_clean() +
  theme(
    legend.position = "bottom",
    axis.title = element_text(size = textSize_axisTitle),
    plot.title = element_text(size = textSize_plotTitle),
    plot.subtitle = element_text(size = textSize_plotSubtitle)
  )

plot_RQ1_AAVS


plot_RQ2_AAVS <- ggplot(
  data_meContrasts_AAVS %>%
    dplyr::filter(contrast == "after - before"),
    aes(x = .value, y = group, fill = robust)
) +
  geom_vline(xintercept = 0, alpha = .3) +
  stat_halfeye(alpha = .9) +
  scale_fill_manual(values = c("#E3B5CF", "#CC79A7"),
                     drop = FALSE) +
  labs(
    x = "Average marginal effect of after-sensor\neffects (mel²)",
    y = NULL,
    title = "(c) Research Question 2",
    subtitle = "After-sensor effect (After Sensors -\nBefore Sensors) per group and the\neffect contrast between groups.",
    fill = "Robust at 95% HPD Interval & pd"
  ) +
  scale_y_discrete(limits = rev) +
  theme_clean() +
  theme(
    legend.position = "bottom",
    axis.title = element_text(size = textSize_axisTitle),
    plot.title = element_text(size = textSize_plotTitle),
    plot.subtitle = element_text(size = textSize_plotSubtitle)
  )

plot_RQ2_AAVS


# Combined plot
plot_AAVS <-  plot_grandMean_AAVS + plot_RQ1_AAVS + plot_RQ2_AAVS +
  patchwork::plot_layout(ncol = 3, heights = c(1), guides = "collect") +
  plot_annotation(title = "Articulatory Acoustic Vowel Space", #subtitle = "Predicted intelligibility ratings across group/severity and speaking conditions.",
                  theme = theme_clean()) &
  theme(legend.position = "bottom")
plot_AAVS

ggsave(
  plot = plot_AAVS,
  filename = "Figures/Fig_AAVS.png",
  height = 6,
  width = 10,
  unit = "in",
  scale = .9,
  bg = "white"
)

04. M1

/s/ - Expected Posteriors

# Generate expected predictions from the posterior
data_posterior_M1s <- model_M1s %>%
  tidybayes::epred_draws(
    newdata = tidyr::expand_grid(
      group = c("Control", "PD"),
      time_point = c("before", "sensors", "after"),
      sex = c("Male", "Female"),
      age = mean(model_M1s$data$age),
      artic_rate = mean(model_M1s$data$artic_rate),
    ),
    re_formula = NA
  ) %>%
  group_by(.draw, group, time_point) %>%
  summarize(.epred = mean(.epred), .groups = "drop") %>%
  dplyr::mutate(
    group = factor(
      group,
      levels = c("Control", "PD"),
      labels = c("Control", "PwPD")
    ),
    #grouping = paste(sex, group, sep = " - "),
    #grouping = factor(grouping,
    #                  levels = c("Male - Control",
    #                             "Male - PwPD",
    #                             "Female - Control",
    #                             "Female - PwPD")),
    time_point = factor(
      time_point,
      levels = c("before", "sensors", "after"),
      labels = c("Before\nSensors", "With\nSensors", "After\nSensors")
    )
  )

/s/ - ME: Timepoint x Group

robust_M1s <- rio::import("workingData/data_M1s.RDS")$pairwise %>%
  dplyr::select(contrast, group, robust)
Warning: Missing `trust` will be set to FALSE by default for RDS in 2.0.0.
data_meContrasts_M1s <- model_M1s %>%
  emmeans::emmeans(~ time_point | group,
                   epred = TRUE,
                   re_formula = NA,) %>%
  emmeans::contrast(method = "revpairwise") %>%
  gather_emmeans_draws() %>%
  dplyr::filter(contrast != "after - sensors")

# Compute the interaction contrast (difference in contrasts between groups)
interaction_contrast <- model_M1s %>%
  emmeans::emmeans(~ time_point * group, epred = TRUE, re_formula = NA) %>%
  emmeans::contrast(interaction = "revpairwise") %>%
  gather_emmeans_draws() %>%
  dplyr::rename(contrast = time_point_revpairwise,
                group = group_revpairwise) %>%
  dplyr::filter(contrast != "after - sensors")

data_meContrasts_M1s <- base::rbind(data_meContrasts_M1s, interaction_contrast) %>%
  dplyr::mutate(group = case_when(
    group == "PD" ~ "PwPD",
    group == "Control" ~ "Control",
    group == "PD - Control" ~ "PwPD -\nControl"
  )) %>%
  base::merge(., robust_M1s) %>%
  dplyr::mutate(robust = factor(robust,
                                levels = c("not robust",
                                           "robust")))

#bayestestR::p_direction(data_meContrasts_M1s)

/sh/ - Expected Posteriors

# Generate expected predictions from the posterior
data_posterior_M1sh <- model_M1sh %>%
  tidybayes::epred_draws(
    newdata = tidyr::expand_grid(
      group = c("Control", "PD"),
      time_point = c("before", "sensors", "after"),
      sex = c("Male", "Female"),
      age = mean(model_M1sh$data$age),
      artic_rate = mean(model_M1sh$data$artic_rate),
    ),
    re_formula = NA
  ) %>%
  group_by(.draw, group, time_point) %>%
  summarize(.epred = mean(.epred), .groups = "drop") %>%
  dplyr::mutate(
    group = factor(
      group,
      levels = c("Control", "PD"),
      labels = c("Control", "PwPD")
    ),
    #grouping = paste(sex, group, sep = " - "),
    #grouping = factor(grouping,
    #                  levels = c("Male - Control",
    #                             "Male - PwPD",
    #                             "Female - Control",
    #                             "Female - PwPD")),
    time_point = factor(
      time_point,
      levels = c("before", "sensors", "after"),
      labels = c("Before\nSensors", "With\nSensors", "After\nSensors")
    )
  )

/sh/ - ME: Timepoint x Group

robust_M1sh <- rio::import("workingData/data_M1sh.RDS")$pairwise %>%
  dplyr::select(contrast, group, robust)
Warning: Missing `trust` will be set to FALSE by default for RDS in 2.0.0.
data_meContrasts_M1sh <- model_M1sh %>%
  emmeans::emmeans(~ time_point | group,
                   epred = TRUE,
                   re_formula = NA,) %>%
  emmeans::contrast(method = "revpairwise") %>%
  gather_emmeans_draws() %>%
  dplyr::filter(contrast != "after - sensors")

# Compute the interaction contrast (difference in contrasts between groups)
interaction_contrast <- model_M1sh %>%
  emmeans::emmeans(~ time_point * group, epred = TRUE, re_formula = NA) %>%
  emmeans::contrast(interaction = "revpairwise") %>%
  gather_emmeans_draws() %>%
  dplyr::rename(contrast = time_point_revpairwise,
                group = group_revpairwise) %>%
  dplyr::filter(contrast != "after - sensors")

data_meContrasts_M1sh <- base::rbind(data_meContrasts_M1sh, interaction_contrast) %>%
  dplyr::mutate(group = case_when(
    group == "PD" ~ "PwPD",
    group == "Control" ~ "Control",
    group == "PD - Control" ~ "PwPD -\nControl"
  )) %>%
  base::merge(., robust_M1sh) %>%
  dplyr::mutate(robust = factor(robust,
                                levels = c("not robust",
                                           "robust")))

#bayestestR::p_direction(data_meContrasts_M1sh)

Combined

Expected Posteriors

# Generate expected predictions from the posterior
data_posterior_M1 <- rbind(data_posterior_M1s %>%
                             dplyr::mutate(sound = "/s/"),
                           data_posterior_M1sh %>%
                             dplyr::mutate(sound = "/ʃ/"))

plot_grandMean_M1 <- ggplot(data_posterior_M1, 
                                   aes(x = .epred, y = time_point, 
                                       fill = group)) +
  stat_halfeye(alpha = .9) +
  ggokabeito::scale_fill_okabe_ito(order = c(2, 1)) +
  labs(x = "Predicted M1 (kHz)", y = NULL,
       fill = "Group",
       title = "(a) Posterior Predictions",
       subtitle = "Predicted M1 after controlling for\nspeaker age, sex, and articulation rate.") +
  scale_y_discrete(limits = rev) +
  theme_clean() +
  facet_wrap(~sound, ncol = 1) +
  theme(legend.position = "bottom",
        axis.title = element_text(size = textSize_axisTitle),
        plot.title = element_text(size = textSize_plotTitle),
        plot.subtitle = element_text(size = textSize_plotSubtitle))  +
  guides(fill = guide_legend(nrow = 1))

ME: Timepoint x Group

data_meContrasts_M1 <- rbind(data_meContrasts_M1s %>%
                             dplyr::mutate(sound = "/s/"),
                           data_meContrasts_M1sh %>%
                             dplyr::mutate(sound = "/ʃ/"))

#bayestestR::p_direction(data_meContrasts_M1)

plot_RQ1_M1 <- ggplot(
  data_meContrasts_M1 %>%
    dplyr::filter(contrast == "sensors - before"),
  aes(x = .value, y = group, fill = robust)
) +
  geom_vline(xintercept = 0, alpha = .3) +
  stat_halfeye(alpha = .9) +
  scale_fill_manual(values = c("#E3B5CF", "#CC79A7"),
                     drop = FALSE) +
  labs(
    x = "Average marginal effect of sensors effects (kHz)",
    y = NULL,
    title = "(b) Research Question 1",
    subtitle = "Sensor effect (With Sensors - Before Sensors)\nper group and the effect contrast between groups.",
    fill = "Robust at 95% HPD Interval & pd"
  ) +
  scale_y_discrete(limits = rev) +
  facet_wrap(~sound, ncol = 1) +
  theme_clean() +
  theme(
    legend.position = "bottom",
    axis.title = element_text(size = textSize_axisTitle),
    plot.title = element_text(size = textSize_plotTitle),
    plot.subtitle = element_text(size = textSize_plotSubtitle)
  )

plot_RQ1_M1


plot_RQ2_M1 <- ggplot(
  data_meContrasts_M1 %>%
    dplyr::filter(contrast == "after - before"),
  aes(x = .value, y = group, fill = robust)
) +
  geom_vline(xintercept = 0, alpha = .3) +
  stat_halfeye(alpha = .9) +
  scale_fill_manual(values = c("#E3B5CF", "#CC79A7"),
                     drop = FALSE) +
  labs(
    x = "Average marginal effect of after-sensor\neffects (kHz)",
    y = NULL,
    title = "(c) Research Question 2",
    subtitle = "After-sensor effect (After Sensors -\nBefore Sensors) per group and the\neffect contrast between groups.",
    fill = "Robust at 95% HPD Interval & pd"
  ) +
  scale_y_discrete(limits = rev) +
  facet_wrap(~sound, ncol = 1) +
  theme_clean() +
  theme(
    legend.position = "bottom",
    axis.title = element_text(size = textSize_axisTitle),
    plot.title = element_text(size = textSize_plotTitle),
    plot.subtitle = element_text(size = textSize_plotSubtitle)
  )

plot_RQ2_M1


# Combined plot
plot_M1 <-  plot_grandMean_M1 + plot_RQ1_M1 + plot_RQ2_M1 +
  patchwork::plot_layout(ncol = 3, heights = c(1), guides = "collect") +
  plot_annotation(title = "Spectral Center of Gravity (M1)", #subtitle = "Predicted intelligibility ratings across group/severity and speaking conditions.",
                  theme = theme_clean()) &
  theme(legend.position = "bottom")
plot_M1

ggsave(
  plot = plot_M1,
  filename = "Figures/Fig_M1.png",
  height = 7,
  width = 10,
  unit = "in",
  scale = .9,
  bg = "white"
)

05. M2

/s/ - Expected Posteriors

# Generate expected predictions from the posterior
data_posterior_M2s <- model_M2s %>%
  tidybayes::epred_draws(
    newdata = tidyr::expand_grid(
      group = c("Control", "PD"),
      time_point = c("before", "sensors", "after"),
      sex = c("Male", "Female"),
      age = mean(model_M2s$data$age),
      artic_rate = mean(model_M2s$data$artic_rate),
    ),
    re_formula = NA
  ) %>%
  group_by(.draw, group, time_point) %>%
  summarize(.epred = mean(.epred), .groups = "drop") %>%
  dplyr::mutate(
    group = factor(
      group,
      levels = c("Control", "PD"),
      labels = c("Control", "PwPD")
    ),
    #grouping = paste(sex, group, sep = " - "),
    #grouping = factor(grouping,
    #                  levels = c("Male - Control",
    #                             "Male - PwPD",
    #                             "Female - Control",
    #                             "Female - PwPD")),
    time_point = factor(
      time_point,
      levels = c("before", "sensors", "after"),
      labels = c("Before\nSensors", "With\nSensors", "After\nSensors")
    )
  )

/s/ - ME: Timepoint x Group

robust_M2s <- rio::import("workingData/data_M2s.RDS")$pairwise %>%
  dplyr::select(contrast, group, robust)
Warning: Missing `trust` will be set to FALSE by default for RDS in 2.0.0.
data_meContrasts_M2s <- model_M2s %>%
  emmeans::emmeans(~ time_point | group,
                   epred = TRUE,
                   re_formula = NA,) %>%
  emmeans::contrast(method = "revpairwise") %>%
  gather_emmeans_draws() %>%
  dplyr::filter(contrast != "after - sensors")

# Compute the interaction contrast (difference in contrasts between groups)
interaction_contrast <- model_M2s %>%
  emmeans::emmeans(~ time_point * group, epred = TRUE, re_formula = NA) %>%
  emmeans::contrast(interaction = "revpairwise") %>%
  gather_emmeans_draws() %>%
  dplyr::rename(contrast = time_point_revpairwise,
                group = group_revpairwise) %>%
  dplyr::filter(contrast != "after - sensors")

data_meContrasts_M2s <- base::rbind(data_meContrasts_M2s, interaction_contrast) %>%
  dplyr::mutate(group = case_when(
    group == "PD" ~ "PwPD",
    group == "Control" ~ "Control",
    group == "PD - Control" ~ "PwPD -\nControl"
  )) %>%
  base::merge(., robust_M2s) %>%
  dplyr::mutate(robust = factor(robust,
                                levels = c("not robust",
                                           "robust")))

#bayestestR::p_direction(data_meContrasts_M2s)

/sh/ - Expected Posteriors

# Generate expected predictions from the posterior
data_posterior_M2sh <- model_M2sh %>%
  tidybayes::epred_draws(
    newdata = tidyr::expand_grid(
      group = c("Control", "PD"),
      time_point = c("before", "sensors", "after"),
      sex = c("Male", "Female"),
      age = mean(model_M2sh$data$age),
      artic_rate = mean(model_M2sh$data$artic_rate),
    ),
    re_formula = NA
  ) %>%
  group_by(.draw, group, time_point) %>%
  summarize(.epred = mean(.epred), .groups = "drop") %>%
  dplyr::mutate(
    group = factor(
      group,
      levels = c("Control", "PD"),
      labels = c("Control", "PwPD")
    ),
    #grouping = paste(sex, group, sep = " - "),
    #grouping = factor(grouping,
    #                  levels = c("Male - Control",
    #                             "Male - PwPD",
    #                             "Female - Control",
    #                             "Female - PwPD")),
    time_point = factor(
      time_point,
      levels = c("before", "sensors", "after"),
      labels = c("Before\nSensors", "With\nSensors", "After\nSensors")
    )
  )

/sh/ - ME: Timepoint x Group

robust_M2sh <- rio::import("workingData/data_M2sh.RDS")$pairwise %>%
  dplyr::select(contrast, group, robust)
Warning: Missing `trust` will be set to FALSE by default for RDS in 2.0.0.
data_meContrasts_M2sh <- model_M2sh %>%
  emmeans::emmeans(~ time_point | group,
                   epred = TRUE,
                   re_formula = NA,) %>%
  emmeans::contrast(method = "revpairwise") %>%
  gather_emmeans_draws() %>%
  dplyr::filter(contrast != "after - sensors")

# Compute the interaction contrast (difference in contrasts between groups)
interaction_contrast <- model_M2sh %>%
  emmeans::emmeans(~ time_point * group, epred = TRUE, re_formula = NA) %>%
  emmeans::contrast(interaction = "revpairwise") %>%
  gather_emmeans_draws() %>%
  dplyr::rename(contrast = time_point_revpairwise,
                group = group_revpairwise) %>%
  dplyr::filter(contrast != "after - sensors")

data_meContrasts_M2sh <- base::rbind(data_meContrasts_M2sh, interaction_contrast) %>%
  dplyr::mutate(group = case_when(
    group == "PD" ~ "PwPD",
    group == "Control" ~ "Control",
    group == "PD - Control" ~ "PwPD -\nControl"
  )) %>%
  base::merge(., robust_M2sh) %>%
  dplyr::mutate(robust = factor(robust,
                                levels = c("not robust",
                                           "robust")))

#bayestestR::p_direction(data_meContrasts_M2sh)

Combined

Expected Posteriors

# Generate expected predictions from the posterior
data_posterior_M2 <- rbind(data_posterior_M2s %>%
                             dplyr::mutate(sound = "/s/"),
                           data_posterior_M2sh %>%
                             dplyr::mutate(sound = "/ʃ/"))

plot_grandMean_M2 <- ggplot(data_posterior_M2, 
                                   aes(x = .epred, y = time_point, 
                                       fill = group)) +
  stat_halfeye(alpha = .9) +
  ggokabeito::scale_fill_okabe_ito(order = c(2, 1)) +
  labs(x = "Predicted M2 (kHz)", y = NULL,
       fill = "Group",
       title = "(a) Posterior Predictions",
       subtitle = "Predicted M2 after controlling for\nspeaker age, sex, and articulation rate.") +
  scale_y_discrete(limits = rev) +
  theme_clean() +
  facet_wrap(~sound, ncol = 1) +
  theme(legend.position = "bottom",
        axis.title = element_text(size = textSize_axisTitle),
        plot.title = element_text(size = textSize_plotTitle),
        plot.subtitle = element_text(size = textSize_plotSubtitle))  +
  guides(fill = guide_legend(nrow = 1))

ME: Timepoint x Group

data_meContrasts_M2 <- rbind(data_meContrasts_M2s %>%
                             dplyr::mutate(sound = "/s/"),
                           data_meContrasts_M2sh %>%
                             dplyr::mutate(sound = "/ʃ/"))

#bayestestR::p_direction(data_meContrasts_M2)

plot_RQ1_M2 <- ggplot(
  data_meContrasts_M2 %>%
    dplyr::filter(contrast == "sensors - before"),
  aes(x = .value, y = group, fill = robust)
) +
  geom_vline(xintercept = 0, alpha = .3) +
  stat_halfeye(alpha = .9) +
  scale_fill_manual(values = c("#E3B5CF", "#CC79A7"),
                     drop = FALSE) +
  labs(
    x = "Average marginal effect of sensors effects (kHz)",
    y = NULL,
    title = "(b) Research Question 1",
    subtitle = "Sensor effect (With Sensors - Before Sensors)\nper group and the effect contrast between groups.",
    fill = "Robust at 95% HPD Interval & pd"
  ) +
  scale_y_discrete(limits = rev) +
  facet_wrap(~sound, ncol = 1) +
  theme_clean() +
  theme(
    legend.position = "bottom",
    axis.title = element_text(size = textSize_axisTitle),
    plot.title = element_text(size = textSize_plotTitle),
    plot.subtitle = element_text(size = textSize_plotSubtitle)
  )

plot_RQ1_M2


plot_RQ2_M2 <- ggplot(
  data_meContrasts_M2 %>%
    dplyr::filter(contrast == "after - before"),
  aes(x = .value, y = group, fill = robust)
) +
  geom_vline(xintercept = 0, alpha = .3) +
  stat_halfeye(alpha = .9) +
  scale_fill_manual(values = c("#E3B5CF", "#CC79A7"),
                     drop = FALSE) +
  labs(
    x = "Average marginal effect of after-sensor\neffects (kHz)",
    y = NULL,
    title = "(c) Research Question 2",
    subtitle = "After-sensor effect (After Sensors -\nBefore Sensors) per group and the\neffect contrast between groups.",
    fill = "Robust at 95% HPD Interval & pd"
  ) +
  scale_y_discrete(limits = rev) +
  facet_wrap(~sound, ncol = 1) +
  theme_clean() +
  theme(
    legend.position = "bottom",
    axis.title = element_text(size = textSize_axisTitle),
    plot.title = element_text(size = textSize_plotTitle),
    plot.subtitle = element_text(size = textSize_plotSubtitle)
  )

plot_RQ2_M2


# Combined plot
plot_M2 <-  plot_grandMean_M2 + plot_RQ1_M2 + plot_RQ2_M2 +
  patchwork::plot_layout(ncol = 3, heights = c(1), guides = "collect") +
  plot_annotation(title = "Spectral Standard Deviation (M2)", #subtitle = "Predicted intelligibility ratings across group/severity and speaking conditions.",
                  theme = theme_clean()) &
  theme(legend.position = "bottom")
plot_M2

ggsave(
  plot = plot_M2,
  filename = "Figures/Fig_M2.png",
  height = 7,
  width = 10,
  unit = "in",
  scale = .9,
  bg = "white"
)

06. Intelligibility

Expected Posteriors

epsilon <- 1e-5
# Generate expected predictions from the posterior
data_posterior_Int <- model_Int %>%
  tidybayes::epred_draws(
    newdata = tidyr::expand_grid(
      group = c("Control", "PD"),
      time_point = c("before", "sensors", "after"),
      sex = c("Male", "Female"),
      age = mean(model_Int$data$age), # 66.91 yo
      artic_rate = mean(model_Int$data$artic_rate), # 4.85 syl/s
      trial_number = mean(model_Int$data$trial_number) # trial 9
    ),
    re_formula = NA
  ) %>%
  group_by(.draw, group, time_point) %>%
  summarize(.epred = mean(.epred), .groups = "drop") %>%
  dplyr::mutate(
    group = factor(
      group,
      levels = c("Control", "PD"),
      labels = c("Control", "PwPD")
    ),
    #grouping = paste(sex, group, sep = " - "),
    #grouping = factor(grouping,
    #                  levels = c("Male - Control",
    #                             "Male - PwPD",
    #                             "Female - Control",
    #                             "Female - PwPD")),
    time_point = factor(
      time_point,
      levels = c("before", "sensors", "after"),
      labels = c("Before\nSensors", "With\nSensors", "After\nSensors")
    ),
    .epred = (.epred - epsilon) / (1 - 2 * epsilon),
    # Step 1 & 2: Reverse the offset and scaling
    .epred = .epred * nrow(.) / ((nrow(.) - 1) + .5),
    .epred = .epred * 100 # to turn it back to a scale of 0 - 100
  )

plot_grandMean_Int <- ggplot(data_posterior_Int, 
                                   aes(x = .epred, y = time_point, 
                                       fill = group)) +
  stat_halfeye(alpha = .9) +
  ggokabeito::scale_fill_okabe_ito(order = c(2, 1)) +
  labs(x = "Predicted intelligibility rating (%)", y = NULL,
       fill = "Group",
       title = "(a) Posterior Predictions",
       subtitle = "Predicted intelligibility rating after controlling\nfor speaker age, sex, articulation rate,\nand trial number.") +
  scale_y_discrete(limits = rev) +
  coord_cartesian(xlim = c(72,100)) +
  theme_clean() +
  theme(legend.position = "bottom",
        axis.title = element_text(size = textSize_axisTitle),
        plot.title = element_text(size = textSize_plotTitle),
        plot.subtitle = element_text(size = textSize_plotSubtitle),
        #panel.border = element_rect(color = "grey", fill = NA)
        ) +
  guides(fill = guide_legend(nrow = 1))

ME: Timepoint x Group

robust_Int <- rio::import("workingData/data_Int.RDS")$pairwise %>%
  dplyr::select(contrast, group, robust)
Warning: Missing `trust` will be set to FALSE by default for RDS in 2.0.0.
epsilon <- 1e-5
data_meContrasts_Int <- model_Int %>%
  emmeans::emmeans(~ time_point | group,
                   epred = TRUE,
                   re_formula = NA,) %>%
  emmeans::contrast(method = "revpairwise") %>%
  gather_emmeans_draws() %>%
  dplyr::mutate(
    .value = (.value - epsilon) / (1 - 2 * epsilon),
    # Step 1 & 2: Reverse the offset and scaling
    .value = .value * nrow(.) / ((nrow(.) - 1) + .5),
    .value = .value * 100
  ) %>%
  dplyr::filter(contrast != "after - sensors")

# Compute the interaction contrast (difference in contrasts between groups)
interaction_contrast <- model_Int %>%
  emmeans::emmeans(~ time_point * group, epred = TRUE, re_formula = NA) %>%
  emmeans::contrast(interaction = "revpairwise") %>%
  gather_emmeans_draws() %>%
  dplyr::mutate(
    .value = (.value - epsilon) / (1 - 2 * epsilon),
    # Step 1 & 2: Reverse the offset and scaling
    .value = .value * nrow(.) / ((nrow(.) - 1) + .5),
    .value = .value * 100
  ) %>%
  dplyr::rename(contrast = time_point_revpairwise,
                group = group_revpairwise) %>%
  dplyr::filter(contrast != "after - sensors")

data_meContrasts_Int <- base::rbind(data_meContrasts_Int, interaction_contrast) %>%
  dplyr::mutate(group = case_when(
    group == "PD" ~ "PwPD",
    group == "Control" ~ "Control",
    group == "PD - Control" ~ "PwPD -\nControl"
  )) %>%
  base::merge(., robust_Int) %>%
  dplyr::mutate(robust = factor(robust,
                                levels = c("not robust",
                                           "robust")))

plot_RQ1_Int <- ggplot(
  data_meContrasts_Int %>%
    dplyr::filter(contrast == "sensors - before"),
  aes(x = .value, y = group, fill = robust)
) +
  geom_vline(xintercept = 0, alpha = .3) +
  stat_halfeye(alpha = .9) +
  scale_fill_manual(values = c("#E3B5CF", "#CC79A7"),
                     drop = FALSE) +
  # Text annotation for the Control and PwPD distributions
  annotate(
    'text',
    x = -.13*100, # Play around with the coordinates until you're satisfied
    y = 3.3,
    label = "Both Control and PwPD\nwere robustly less intelligbile\nwith EMA sensors on...",
    hjust = 0,
    size = 2,
    alpha = .8,
    color = "black"
  ) +
  # Arrow to the Control distribution
  annotate(
    'curve',
    x = -.095*100, # Play around with the coordinates until you're satisfied
    y = 3.1,
    xend = -.03*100,
    yend = 2.96,
    linewidth = .4,
    curvature = 0.2,
    arrow = arrow(length = unit(0.1, 'cm'), type = "closed"),
    alpha = 1,
    color = "darkgrey"
  ) +
  # Arrow to the PwPD distribution
  annotate(
    'curve',
    x = -.096*100, # Play around with the coordinates until you're satisfied
    y = 3.1,
    xend = -.065*100,
    yend = 2.3,
    linewidth = .4,
    curvature = 0.2,
    arrow = arrow(length = unit(0.1, 'cm'), type = "closed"),
    alpha = 1,
    color = "darkgrey"
  ) +
  # Text for the contrast distribution
  annotate(
    'text',
    x = -.07*100, # Play around with the coordinates until you're satisfied
    y = 0.73,
    label = "... but these effects\nwere robustly different\nbetween the groups.",
    hjust = 1,
    size = 2,
    alpha = .8,
    color = "black"
  ) +
    # Arrow to the contrast distribution
  annotate(
    'curve',
    x = -.065*100, # Play around with the coordinates until you're satisfied
    y = 0.73,
    xend = -.045*100,
    yend = .95,
    linewidth = .4,
    curvature = 0.2,
    arrow = arrow(length = unit(0.1, 'cm'), type = "closed"),
    alpha = 1,
    color = "darkgrey"
  ) +
  labs(
    x = "Average marginal effect of sensors effects (%)",
    y = NULL,
    title = "(b) Research Question 1",
    subtitle = "Sensor effect (With Sensors - Before Sensors)\nper group and the effect contrast between groups.",
    fill = "Robust at 95% HPD Interval & pd"
  ) +
  scale_y_discrete(limits = rev) +
  theme_clean() +
  theme(
    legend.position = "bottom",
    axis.title = element_text(size = textSize_axisTitle),
    plot.title = element_text(size = textSize_plotTitle),
    plot.subtitle = element_text(size = textSize_plotSubtitle)
  )

plot_RQ1_Int


plot_RQ2_Int <- ggplot(
  data_meContrasts_Int %>%
    dplyr::filter(contrast == "after - before"),
    aes(x = .value, y = group, fill = robust)
) +
  geom_vline(xintercept = 0, alpha = .3) +
  stat_halfeye(alpha = .9) +
  scale_fill_manual(values = c("#E3B5CF", "#CC79A7"),
                     drop = FALSE) +
  labs(
    x = "Average marginal effect of after-sensor\neffects (%)",
    y = NULL,
    title = "(c) Research Question 2",
    subtitle = "After-sensor effect (After Sensors -\nBefore Sensors) per group and the\neffect contrast between groups.",
    fill = "Robust at 95% HPD Interval & pd"
  ) +
  scale_y_discrete(limits = rev) +
  theme_clean() +
  theme(
    legend.position = "bottom",
    axis.title = element_text(size = textSize_axisTitle),
    plot.title = element_text(size = textSize_plotTitle),
    plot.subtitle = element_text(size = textSize_plotSubtitle)
  )

plot_RQ2_Int


# Combined plot
plot_Int <-  plot_grandMean_Int + plot_RQ1_Int + plot_RQ2_Int +
  patchwork::plot_layout(ncol = 3, heights = c(1), guides = "collect") +
  plot_annotation(title = "Intelligibility", #subtitle = "Predicted intelligibility ratings across group/severity and speaking conditions.",
                  theme = theme_clean()) &
  theme(legend.position = "bottom")
plot_Int

ggsave(
  plot = plot_Int,
  filename = "Figures/Fig_Int.png",
  height = 6,
  width = 10,
  unit = "in",
  scale = .9,
  bg = "white"
)

07. Naturalness

Expected Posteriors

epsilon <- 1e-5
# Generate expected predictions from the posterior
data_posterior_Nat <- model_Nat %>%
  tidybayes::epred_draws(
    newdata = tidyr::expand_grid(
      group = c("Control", "PD"),
      time_point = c("before", "sensors", "after"),
      sex = c("Male", "Female"),
      age = mean(model_Nat$data$age), # 66.91 yo
      artic_rate = mean(model_Nat$data$artic_rate), # 4.85 syl/s
      trial_number = mean(model_Nat$data$trial_number) # trial 9
    ),
    re_formula = NA
  ) %>%
  group_by(.draw, group, time_point) %>%
  summarize(.epred = mean(.epred), .groups = "drop") %>%
  dplyr::mutate(
    group = factor(
      group,
      levels = c("Control", "PD"),
      labels = c("Control", "PwPD")
    ),
    #grouping = paste(sex, group, sep = " - "),
    #grouping = factor(grouping,
    #                  levels = c("Male - Control",
    #                             "Male - PwPD",
    #                             "Female - Control",
    #                             "Female - PwPD")),
    time_point = factor(
      time_point,
      levels = c("before", "sensors", "after"),
      labels = c("Before\nSensors", "With\nSensors", "After\nSensors")
    ),
    .epred = (.epred - epsilon) / (1 - 2 * epsilon),
    # Step 1 & 2: Reverse the offset and scaling
    .epred = .epred * nrow(.) / ((nrow(.) - 1) + .5),
    .epred = .epred * 100
  )

plot_grandMean_Nat <- ggplot(data_posterior_Nat, 
                                   aes(x = .epred, y = time_point, 
                                       fill = group)) +
  stat_halfeye(alpha = .9) +
  ggokabeito::scale_fill_okabe_ito(order = c(2, 1)) +
  labs(x = "Predicted naturalness rating (%)", y = NULL,
       fill = "Group",
       title = "(a) Posterior Predictions",
       subtitle = "Predicted naturalness rating after controlling\nfor speaker age, sex, articulation rate,\nand trial number.") +
  scale_y_discrete(limits = rev) +
  coord_cartesian(xlim = c(0,100)) +
  theme_clean() +
  theme(legend.position = "bottom",
        axis.title = element_text(size = textSize_axisTitle),
        plot.title = element_text(size = textSize_plotTitle),
        plot.subtitle = element_text(size = textSize_plotSubtitle))  +
  guides(fill = guide_legend(nrow = 1))

ME: Timepoint x Group

robust_Nat <- rio::import("workingData/data_Nat.RDS")$pairwise %>%
  dplyr::select(contrast, group, robust)
Warning: Missing `trust` will be set to FALSE by default for RDS in 2.0.0.
epsilon <- 1e-5
data_meContrasts_Nat <- model_Nat %>%
  emmeans::emmeans(~ time_point | group,
                   epred = TRUE,
                   re_formula = NA,) %>%
  emmeans::contrast(method = "revpairwise") %>%
  gather_emmeans_draws() %>%
  dplyr::mutate(
    .value = (.value - epsilon) / (1 - 2 * epsilon),
    # Step 1 & 2: Reverse the offset and scaling
    .value = .value * nrow(.) / ((nrow(.) - 1) + .5),
    .value = .value * 100
  ) %>%
  dplyr::filter(contrast != "after - sensors")

# Compute the interaction contrast (difference in contrasts between groups)
interaction_contrast <- model_Nat %>%
  emmeans::emmeans(~ time_point * group, epred = TRUE, re_formula = NA) %>%
  emmeans::contrast(interaction = "revpairwise") %>%
  gather_emmeans_draws() %>%
  dplyr::mutate(
    .value = (.value - epsilon) / (1 - 2 * epsilon),
    # Step 1 & 2: Reverse the offset and scaling
    .value = .value * nrow(.) / ((nrow(.) - 1) + .5),
    .value = .value * 100
  ) %>%
  dplyr::rename(contrast = time_point_revpairwise,
                group = group_revpairwise) %>%
  dplyr::filter(contrast != "after - sensors")

data_meContrasts_Nat <- base::rbind(data_meContrasts_Nat, interaction_contrast)  %>%
  dplyr::mutate(group = case_when(
    group == "PD" ~ "PwPD",
    group == "Control" ~ "Control",
    group == "PD - Control" ~ "PwPD -\nControl"
  )) %>%
  base::merge(., robust_Nat) %>%
  dplyr::mutate(robust = factor(robust,
                                levels = c("not robust",
                                           "robust")))

#bayestestR::p_direction(data_meContrasts_Nat)

plot_RQ1_Nat <- ggplot(
  data_meContrasts_Nat %>%
    dplyr::filter(contrast == "sensors - before"),
    aes(x = .value, y = group, fill = robust)
) +
  geom_vline(xintercept = 0, alpha = .3) +
  stat_halfeye(alpha = .9) +
  scale_fill_manual(values = c("#E3B5CF", "#CC79A7"),
                     drop = FALSE) +
  labs(
    x = "Average marginal effect of sensors effects (%)",
    y = NULL,
    title = "(b) Research Question 1",
    subtitle = "Sensor effect (With Sensors - Before Sensors)\nper group and the effect contrast between groups.",
    fill = "Robust at 95% HPD Interval & pd"
  ) +
  scale_y_discrete(limits = rev) +
  theme_clean() +
  theme(
    legend.position = "bottom",
    axis.title = element_text(size = textSize_axisTitle),
    plot.title = element_text(size = textSize_plotTitle),
    plot.subtitle = element_text(size = textSize_plotSubtitle)
  )

plot_RQ1_Nat


plot_RQ2_Nat <- ggplot(
  data_meContrasts_Nat %>%
    dplyr::filter(contrast == "after - before"),
    aes(x = .value, y = group, fill = robust)
) +
  geom_vline(xintercept = 0, alpha = .3) +
  stat_halfeye(alpha = .9) +
  scale_fill_manual(values = c("#E3B5CF", "#CC79A7"),
                     drop = FALSE) +
  labs(
    x = "Average marginal effect of after-sensors\neffects (%)",
    y = NULL,
    title = "(c) Research Question 2",
    subtitle = "After-sensor effect (After Sensors -\nBefore Sensors) per group and the\neffect contrast between groups.",
    fill = "Robust at 95% HPD Interval & pd"
  ) +
  scale_y_discrete(limits = rev) +
  theme_clean() +
  theme(
    legend.position = "bottom",
    axis.title = element_text(size = textSize_axisTitle),
    plot.title = element_text(size = textSize_plotTitle),
    plot.subtitle = element_text(size = textSize_plotSubtitle)
  )

plot_RQ2_Nat


# Combined plot
plot_Nat <-  plot_grandMean_Nat + plot_RQ1_Nat + plot_RQ2_Nat +
  patchwork::plot_layout(ncol = 3,
                         heights = c(1),
                         guides = "collect") +
  plot_annotation(title = "Naturalness",
                  theme = theme_clean()) &
  theme(legend.position = "bottom")
plot_Nat

ggsave(
  plot = plot_Nat,
  filename = "Figures/Fig_Nat.png",
  height = 6,
  width = 10,
  unit = "in",
  scale = .9,
  bg = "white"
)

S01. Individual Variability

workingData_articRate <- base::readRDS(file = "workingData/data_articRate.RDS")
workingData_AAVS <- base::readRDS(file = "workingData/data_AAVS.RDS")
workingData_M1s <- base::readRDS(file = "workingData/data_M1s.RDS")
workingData_M1sh <- base::readRDS(file = "workingData/data_M1sh.RDS")
workingData_M2s <- base::readRDS(file = "workingData/data_M2s.RDS")
workingData_M2sh <- base::readRDS(file = "workingData/data_M2sh.RDS")
workingData_Int <- base::readRDS(file = "workingData/data_Int.RDS")
workingData_Nat <- base::readRDS(file = "workingData/data_Nat.RDS")

allData <- bind_rows(
  workingData_articRate$modelData %>%
    dplyr::mutate(measure = "Articulation Rate") %>%
    dplyr::rename(value = articRate),
  
  workingData_AAVS$modelData %>%
    dplyr::mutate(measure = "AAVS") %>%
    dplyr::rename(value = AAVS),
  
  workingData_M1s$modelData %>%
    dplyr::mutate(measure = "M1 for /s/") %>%
    dplyr::rename(value = M1s),
  
  workingData_M2s$modelData %>%
    dplyr::mutate(measure = "M2 for /s/") %>%
    dplyr::rename(value = M2s),
  
  workingData_M1sh$modelData %>%
    dplyr::mutate(measure = "M1 for /ʃ/") %>%
    dplyr::rename(value = M1sh),
  
  workingData_M2sh$modelData %>%
    dplyr::mutate(measure = "M2 for /ʃ/") %>%
    dplyr::rename(value = M2sh),
  
  workingData_Int$modelData %>%
    dplyr::mutate(measure = "Intelligibility",
                  Int = Int*100) %>%
    dplyr::rename(value = Int),
  
  workingData_Nat$modelData %>%
    dplyr::mutate(measure = "Naturalness",
                  Nat = Nat*100) %>%
    dplyr::rename(value = Nat)
) %>%
  dplyr::mutate(time_point = factor(time_point,
                                    levels = c("before",
                                               "sensors",
                                               "after"),
                                    labels = c("Before\nSensors",
                                               "With\nSensors",
                                               "After\nSensors")),
                measure = factor(measure,
                                 levels = c("Articulation Rate",
                                            "AAVS",
                                            "M1 for /s/",
                                            "M2 for /s/",
                                            "M1 for /ʃ/",
                                            "M2 for /ʃ/",
                                            "Intelligibility",
                                            "Naturalness"),
                                 labels = c("Articulation Rate (syl/s)",
                                            "AAVS (mel²)",
                                            "M1 for /s/ (kHz)",
                                            "M2 for /s/ (kHz)",
                                            "M1 for /ʃ/ (kHz)",
                                            "M2 for /ʃ/ (kHz)",
                                            "Intelligibility (%)",
                                            "Naturalness (%)")),
                group = factor(group,
                               levels = c("Control",
                                          "PD"),
                               labels = c("Control",
                                          "PwPD")),
                grouping = paste(sex, group, sep = " - "),
                grouping = factor(grouping,
                      levels = c("Male - Control",
                                 "Male - PwPD",
                                 "Female - Control",
                                 "Female - PwPD"))) %>%
  dplyr::group_by(measure, speaker_id, group, sex, grouping, age, time_point) %>%
  dplyr::summarise(value = mean(value)) %>%
  dplyr::ungroup()
`summarise()` has grouped output by 'measure', 'speaker_id', 'group', 'sex', 'grouping', 'age'. You can override using the `.groups` argument.
plotData <- bind_rows(
  allData %>%
    dplyr::mutate(plot = "All Data"),
  allData %>%
    dplyr::filter(time_point != "After\nSensors") %>%
    dplyr::mutate(plot = "Sensor Effects"),
  allData %>%
    dplyr::filter(time_point != "With\nSensors") %>%
    dplyr::mutate(plot = "After-Sensor Effects"),
) %>%
  dplyr::mutate(plot = factor(plot,
                              levels = c("All Data",
                                         "Sensor Effects",
                                         "After-Sensor Effects"),
                              labels = c("All Data",
                                         "Sensor Effects",
                                         "After-Sensor\nEffects"))) %>%
  dplyr::filter(plot != "All Data")

plot_rawData_sensorEffects <- plotData %>%
  dplyr::filter(plot == "Sensor Effects") %>%
  ggplot() +
  aes(x = time_point, y = value, color = group) +
  geom_line(aes(group = speaker_id), alpha = .3) +
  geom_line(
    data = plotData %>%
      dplyr::filter(plot == "Sensor Effects") %>%
      dplyr::group_by(measure, group, sex, time_point, plot) %>%
      dplyr::summarise(value = mean(value)),
    aes(group = group),
    alpha = .8,
    linewidth = 1.5
  ) +
  #geom_point(aes(shape = sex)) +
  ggokabeito::scale_color_okabe_ito(order = c(2,1)) +
  facet_grid(measure ~ sex, scales = "free", switch = "y") +
  labs(x = NULL,
       y = NULL,
       color = "Group",
       shape = "Sex",
       title = "Sensor Effects") +
  scale_x_discrete(expand=expansion(c(.35,.35))) +
  theme_clean() &
  theme(panel.border = element_rect(fill = NA, color = "black"),
        strip.background = element_rect(fill = "white", color = NA),
        strip.placement = "outside",
        strip.text.y.left = element_text(angle = 0, face="plain", hjust = 1),)
`summarise()` has grouped output by 'measure', 'group', 'sex', 'time_point'. You can override using the `.groups` argument.
plot_rawData_sensorEffects


plot_rawData_afterSensorEffects <- plotData %>%
  dplyr::filter(plot == "After-Sensor\nEffects") %>%
  ggplot() +
  aes(x = time_point, y = value, color = group) +
  geom_line(aes(group = speaker_id), alpha = .3) +
  geom_line(
    data = plotData %>%
      dplyr::filter(plot == "After-Sensor\nEffects") %>%
      dplyr::group_by(measure, group, sex, time_point, plot) %>%
      dplyr::summarise(value = mean(value)),
    aes(group = group),
    alpha = .8,
    linewidth = 1.5
  ) +
  #geom_point(aes(shape = sex)) +
  ggokabeito::scale_color_okabe_ito(order = c(2,1)) +
  facet_grid(measure ~ sex, scales = "free") +
  labs(x = NULL,
       y = NULL,
       color = "Group",
       shape = "Sex",
       title = "After-Sensor Effects") +
  scale_x_discrete(expand=expansion(c(.35,.35))) +
  theme_clean() &
  theme(panel.border = element_rect(fill = NA, color = "black"),
        #strip.background = element_rect(fill = "white", color = NA),
        strip.placement = "outside",
        #strip.text.y.left = element_text(angle = 0, face="plain", hjust = 1),
        strip.background = element_blank(),
        strip.text.y. = element_blank())
`summarise()` has grouped output by 'measure', 'group', 'sex', 'time_point'. You can override using the `.groups` argument.
plot_rawData_afterSensorEffects

plot_rawData <- plot_rawData_sensorEffects + plot_rawData_afterSensorEffects +
  patchwork::plot_layout(ncol = 2, #heights = c(1),
                         guides = "collect") +
  plot_annotation(title = "Raw Data", #subtitle = "Predicted intelligibility ratings across group/severity and speaking conditions.",
                  theme = theme_clean()) &
  theme(
    legend.position = "right",
    strip.background.right = element_blank(),
    strip.text.y.right = element_blank()
  )

ggsave(
  plot = plot_rawData,
  filename = "Figures/SupFig_rawData.png",
  height = 10,
  width = 9,
  unit = "in",
  scale = .9,
  bg = "white"
)

---
title: "Vowel Artic in PD: Plots"
output: html_notebook
---

# Packages
```{r}
library(tidyverse)
library(ggrepel)
library(extraDistr)   # install.packages("extraDistr")
library(HDInterval)   # install.packages("HDAPerval")
library(tidybayes)    # install.packages("tidybayes")
library(bayesplot)    # install.packages("bayesplot")
library(modelr)
library(broom.mixed)  # install.packages("broom.mixed")
library(brms)         # install.packages("brms")
library(ggthemes)
library(patchwork)
library(ggokabeito)   # install.packages("ggokabeito")
theme_set(theme_minimal())

# Creating a theme function used for visualizations
theme_clean <- function() {
  theme_minimal(base_family = "Arial") +
    theme(panel.grid.minor = element_blank(),
          plot.title = element_text(face = "bold"),
          axis.title = element_text(face = "bold"),
          strip.text = element_text(face = "bold", size = rel(1), hjust = 0),
          strip.background = element_rect(fill = "grey80", color = NA),
          legend.title = element_text(face = "bold"))
}
```

# Loading the models
```{r}
model_Int <- base::readRDS(file = "Models/brms_Int.rds")
model_Nat <- base::readRDS(file = "Models/brms_Nat.rds")
model_articRate <- base::readRDS(file = "Models/brms_articRate.rds")
model_AAVS <- base::readRDS(file = "Models/brms_AAVS.rds")
model_M1s <- base::readRDS(file = "Models/brms_M1s.rds")
model_M1sh <- base::readRDS(file = "Models/brms_M1sh.rds")
model_M2s <- base::readRDS(file = "Models/brms_M2s.rds")
model_M2sh <- base::readRDS(file = "Models/brms_M2sh.rds")
```

# Formatting info
```{r}
textSize_plotTitle <- 9
textSize_plotSubtitle <- 9
textSize_axisTitle <- 9
```

# 01. Reliability
```{r}
workingData_Int <- base::readRDS(file = "workingData/data_Int.RDS")
workingData_Nat <- base::readRDS(file = "workingData/data_Nat.RDS")

interRel_plotData <- rbind(
  workingData_Int$data %>%
    dplyr::select(c(
      gorilla_id,
      speaker_id,
      `Time Point` = time_point,
      Group = group,
      Sex = sex,
      age,
      rating
    )
    ) %>%
    dplyr::mutate(
      Measure = "Intelligibility"
    ),
  workingData_Nat$data %>%
    dplyr::select(c(
      gorilla_id,
      speaker_id,
      `Time Point` = time_point,
      Group = group,
      Sex = sex,
      age,
      rating
    )
    ) %>%
    dplyr::mutate(
      Measure = "Naturalness"
    )
) %>%
  dplyr::filter(gorilla_id != "10237851") %>%
  dplyr::group_by(speaker_id, `Time Point`, Group, Sex, age, Measure) %>%
  dplyr::summarise(M = mean(rating),
                   sd = sd(rating)) %>%
  dplyr::ungroup() %>%
  dplyr::mutate(`Time Point` = factor(`Time Point`,
                                      levels = c("before",
                                                 "sensors",
                                                 "after"),
                                      labels = c("Before Sensors",
                                                 "With Sensors",
                                                 "After Sensors")),
                Measure = factor(Measure,
                                 levels = c("Intelligibility",
                                            "Naturalness"),
                                 labels = c("Intelligibility Ratings",
                                            "Naturalness Ratings")),
                Group = factor(Group,
                               levels = c("Control",
                                          "PD"),
                               labels = c("Control",
                                          "PwPD")))

interRel_plot <- interRel_plotData %>%
  ggplot() +
  aes(
    x = M,
    y = sd,
    color = Group,
    shape = `Time Point`
  ) +
  geom_point() +
  facet_wrap(~Measure) +
  labs(x = "Average Rating (Mean)",
       y = "Rating Variability (sd)",
       title = "Inter-listener Reliability",
       #subtitle = "The mean and standard deviation of ratings across speakers and time points."
       ) +
  ggokabeito::scale_color_okabe_ito(order = c(2,
                                             #5,
                                             #4,
                                             1)) +
  ggthemes::theme_clean() &
  theme(
    strip.text.x = element_text(hjust = 0, size = 12),
    strip.text.y = element_text(angle = 0),
    plot.background = element_blank(),
    #panel.margin=unit(.05, "lines"),
        panel.border = element_rect(color = "black", fill = NA, size = 1), 
        strip.background = element_rect(color = "black", size = 1),
    #panel.border = element_rect(color = "black", fill = NA, size = 1), 
    legend.position = "bottom",
    legend.box="vertical",
    legend.background = element_rect(color = NA),
    aspect.ratio = 1)

interRel_plot

ggsave(plot = interRel_plot,
       file = "Figures/Fig_Inter-Listener Reliability.png",
       height = 5,
       width = 6.5,
       units = "in",
       scale = 1,
       bg = "white")
```

# 02. Artic Rate
## Expected Posteriors
```{r}
# Generate expected predictions from the posterior
data_posterior_articRate <- model_articRate %>%
  tidybayes::epred_draws(
    newdata = tidyr::expand_grid(
      group = c("Control", "PD"),
      time_point = c("before", "sensors", "after"),
      sex = c("Male", "Female"),
      age = 66.88,
    ),
    re_formula = NA
  ) %>%
  group_by(.draw, group, time_point) %>%
  summarize(.epred = mean(.epred), .groups = "drop") %>%
  dplyr::mutate(
    group = factor(
      group,
      levels = c("Control", "PD"),
      labels = c("Control", "PwPD")
    ),
    #grouping = paste(sex, group, sep = " - "),
    #grouping = factor(grouping,
    #                  levels = c("Male - Control",
    #                             "Male - PwPD",
    #                             "Female - Control",
    #                             "Female - PwPD")),
    time_point = factor(
      time_point,
      levels = c("before", "sensors", "after"),
      labels = c("Before\nSensors", "With\nSensors", "After\nSensors")
    )
  )

plot_grandMean_articRate <- ggplot(data_posterior_articRate, 
                                   aes(x = .epred, y = time_point, fill = group)) +
  stat_halfeye(alpha = .9) +
  ggokabeito::scale_fill_okabe_ito(order = c(2, 1)) +
  labs(x = "Predicted articulation rate (syl/s)", y = NULL,
       fill = "Group",
       title = "(a) Posterior Predictions",
       subtitle = "Predicted articulation rate after\ncontrolling for speaker age and sex.") +
  scale_y_discrete(limits = rev) +
  theme_clean() +
  #facet_grid(sex~.) +
  theme(legend.position = "bottom",
        axis.title = element_text(size = textSize_axisTitle),
        plot.title = element_text(size = textSize_plotTitle),
        plot.subtitle = element_text(size = textSize_plotSubtitle),
        #panel.border = element_rect(color = "grey", fill = NA)
        ) +
  guides(fill = guide_legend(nrow = 1))
```

## ME: Timepoint x Group
```{r}
robust_articRate <- rio::import("workingData/data_articRate.RDS")$pairwise %>%
  dplyr::select(contrast, group, robust)

data_meContrasts_articRate <- model_articRate %>%
  emmeans::emmeans( ~ time_point | group, epred = TRUE, re_formula = NA, ) %>%
  emmeans::contrast(method = "revpairwise") %>%
  gather_emmeans_draws() %>%
  dplyr::filter(contrast != "after - sensors")

# Compute the interaction contrast (difference in contrasts between groups)
interaction_contrast <- model_articRate %>%
  emmeans::emmeans( ~ time_point * group, epred = TRUE, re_formula = NA) %>%
  emmeans::contrast(interaction = "revpairwise") %>%
  gather_emmeans_draws() %>%
  dplyr::rename(contrast = time_point_revpairwise, group = group_revpairwise) %>%
  dplyr::filter(contrast != "after - sensors")

data_meContrasts_articRate <- base::rbind(data_meContrasts_articRate, interaction_contrast) %>%
  dplyr::mutate(group = case_when(
    group == "PD" ~ "PwPD",
    group == "Control" ~ "Control",
    group == "PD - Control" ~ "PwPD -\nControl"
  )) %>%
  base::merge(., robust_articRate)

plot_RQ1_articRate <- ggplot(
  data_meContrasts_articRate %>%
    dplyr::filter(contrast == "sensors - before"),
    aes(x = .value, y = group, fill = robust)
) +
  geom_vline(xintercept = 0, alpha = .3) +
  stat_halfeye(alpha = .9) +
  scale_fill_manual(values = c("#E3B5CF", "#CC79A7"),
                     drop = FALSE) +
  labs(
    x = "Average marginal effect of sensors effects (syl/s)",
    y = NULL,
    title = "(b) Research Question 1",
    subtitle = "Sensor effect (With Sensors - Before Sensors)\nper group and the effect contrast between groups.",
    fill = "Robust at 95% HPD Interval & pd"
  ) +
  scale_y_discrete(limits = rev) +
  theme_clean() +
  theme(
    legend.position = "bottom",
    axis.title = element_text(size = textSize_axisTitle),
    plot.title = element_text(size = textSize_plotTitle),
    plot.subtitle = element_text(size = textSize_plotSubtitle)
  )

plot_RQ1_articRate

plot_RQ2_articRate <- ggplot(
  data_meContrasts_articRate %>%
    dplyr::filter(contrast == "after - before"),
    aes(x = .value, y = group, fill = robust)
) +
  geom_vline(xintercept = 0, alpha = .3) +
  stat_halfeye(alpha = .9) +
  scale_fill_manual(values = c("#E3B5CF", "#CC79A7"),
                     drop = FALSE) +
  labs(
    x = "Average marginal effect of after-sensor\neffects (syl/s)",
    y = NULL,
    title = "(c) Research Question 2",
    subtitle = "After-sensor effect (After Sensors -\nBefore Sensors) per group and the\neffect contrast between groups.",
    fill = "Robust at 95% HPD Interval & pd"
  ) +
  scale_y_discrete(limits = rev) +
  theme_clean() +
  theme(
    legend.position = "bottom",
    axis.title = element_text(size = textSize_axisTitle),
    plot.title = element_text(size = textSize_plotTitle),
    plot.subtitle = element_text(size = textSize_plotSubtitle)
  )

plot_RQ2_articRate

# Combined plot
plot_articRate <-  plot_grandMean_articRate + plot_RQ1_articRate + plot_RQ2_articRate +
  patchwork::plot_layout(ncol = 3, heights = c(1), guides = "collect"
                         ) +
  plot_annotation(title = "Articulation Rate", #subtitle = "Predicted intelligibility ratings across group/severity and speaking conditions.",
                  theme = theme_clean()) &
  theme(legend.position = "bottom")
plot_articRate

ggsave(
  plot = plot_articRate,
  filename = "Figures/Fig_articRate.png",
  height = 6,
  width = 10,
  unit = "in",
  scale = .9,
  bg = "white"
)

```

# 03. AAVS
## Expected Posteriors
```{r}
# Generate expected predictions from the posterior
data_posterior_AAVS <- model_AAVS %>%
  tidybayes::epred_draws(
    newdata = tidyr::expand_grid(
      group = c("Control", "PD"),
      time_point = c("before", "sensors", "after"),
      sex = c("Male", "Female"),
      age = mean(model_AAVS$data$age),
      artic_rate = mean(model_AAVS$data$artic_rate),
    ),
    re_formula = NA
  ) %>%
  group_by(.draw, group, time_point) %>%
  summarize(.epred = mean(.epred), .groups = "drop") %>%
  dplyr::mutate(
    group = factor(
      group,
      levels = c("Control", "PD"),
      labels = c("Control", "PwPD")
    ),
    #grouping = paste(sex, group, sep = " - "),
    #grouping = factor(grouping,
    #                  levels = c("Male - Control",
    #                             "Male - PwPD",
    #                             "Female - Control",
    #                             "Female - PwPD")),
    time_point = factor(
      time_point,
      levels = c("before", "sensors", "after"),
      labels = c("Before\nSensors", "With\nSensors", "After\nSensors")
    )
  )

plot_grandMean_AAVS <- ggplot(data_posterior_AAVS, aes(x = .epred, y = time_point, fill = group)) +
  stat_halfeye(alpha = .9) +
  ggokabeito::scale_fill_okabe_ito(order = c(2, 1)) +
  labs(x = "Predicted AAVS (mel²)", y = NULL,
       fill = "Group",
       title = "(a) Posterior Predictions",
       subtitle = "Predicted AAVS after controlling for\nspeaker age, sex, and articulation rate.") +
  scale_y_discrete(limits = rev) +
  #coord_cartesian(xlim = c(.65,1)) +
  theme_clean() +
  #facet_grid(sex~.) +
  theme(legend.position = "bottom",
        axis.title = element_text(size = textSize_axisTitle),
        plot.title = element_text(size = textSize_plotTitle),
        plot.subtitle = element_text(size = textSize_plotSubtitle),
        #panel.border = element_rect(color = "grey", fill = NA)
        ) +
  guides(fill = guide_legend(nrow = 1))
plot_grandMean_AAVS
```

## ME: Timepoint x Group
```{r}
robust_AAVS <- rio::import("workingData/data_AAVS.RDS")$pairwise %>%
  dplyr::select(contrast, group, robust)

data_meContrasts_AAVS <- model_AAVS %>%
  emmeans::emmeans(~ time_point | group,
                   epred = TRUE,
                   re_formula = NA,) %>%
  emmeans::contrast(method = "revpairwise") %>%
  gather_emmeans_draws() %>%
  dplyr::filter(contrast != "after - sensors")  %>%
  dplyr::mutate(group = case_when(
      group == "PD" ~ "PwPD",
      group == "Control" ~ "Control"
    ))

# Compute the interaction contrast (difference in contrasts between groups)
interaction_contrast <- model_AAVS %>%
  emmeans::emmeans(~ time_point * group, epred = TRUE, re_formula = NA) %>%
  emmeans::contrast(interaction = "revpairwise") %>%
  gather_emmeans_draws() %>%
  dplyr::rename(contrast = time_point_revpairwise,
                group = group_revpairwise) %>%
  dplyr::filter(contrast != "after - sensors")  %>%
  dplyr::mutate(group = case_when(
      group == "PD - Control" ~ "PwPD -\nControl"
    ))

data_meContrasts_AAVS <- base::rbind(data_meContrasts_AAVS, interaction_contrast) %>%
  base::merge(., robust_AAVS) %>%
  dplyr::mutate(
    robust = factor(robust, levels = c("not robust", "robust")))

#bayestestR::p_direction(data_meContrasts_AAVS)

plot_RQ1_AAVS <- ggplot(
  data_meContrasts_AAVS %>%
    dplyr::filter(contrast == "sensors - before"),
  aes(x = .value, y = group, fill = robust)
) +
  geom_vline(xintercept = 0, alpha = .3) +
  stat_halfeye(alpha = .9) +
  scale_fill_manual(values = c("#E3B5CF", "#CC79A7"),
                     drop = FALSE) +
  labs(
    x = "Average marginal effect of sensors effects (mel²)",
    y = NULL,
    title = "(b) Research Question 1",
    subtitle = "Sensor effect (With Sensors - Before Sensors)\nper group and the effect contrast between groups.",
    fill = "Robust at 95% HPD Interval & pd"
  ) +
  scale_y_discrete(limits = rev) +
  theme_clean() +
  theme(
    legend.position = "bottom",
    axis.title = element_text(size = textSize_axisTitle),
    plot.title = element_text(size = textSize_plotTitle),
    plot.subtitle = element_text(size = textSize_plotSubtitle)
  )

plot_RQ1_AAVS

plot_RQ2_AAVS <- ggplot(
  data_meContrasts_AAVS %>%
    dplyr::filter(contrast == "after - before"),
    aes(x = .value, y = group, fill = robust)
) +
  geom_vline(xintercept = 0, alpha = .3) +
  stat_halfeye(alpha = .9) +
  scale_fill_manual(values = c("#E3B5CF", "#CC79A7"),
                     drop = FALSE) +
  labs(
    x = "Average marginal effect of after-sensor\neffects (mel²)",
    y = NULL,
    title = "(c) Research Question 2",
    subtitle = "After-sensor effect (After Sensors -\nBefore Sensors) per group and the\neffect contrast between groups.",
    fill = "Robust at 95% HPD Interval & pd"
  ) +
  scale_y_discrete(limits = rev) +
  theme_clean() +
  theme(
    legend.position = "bottom",
    axis.title = element_text(size = textSize_axisTitle),
    plot.title = element_text(size = textSize_plotTitle),
    plot.subtitle = element_text(size = textSize_plotSubtitle)
  )

plot_RQ2_AAVS

# Combined plot
plot_AAVS <-  plot_grandMean_AAVS + plot_RQ1_AAVS + plot_RQ2_AAVS +
  patchwork::plot_layout(ncol = 3, heights = c(1), guides = "collect") +
  plot_annotation(title = "Articulatory Acoustic Vowel Space", #subtitle = "Predicted intelligibility ratings across group/severity and speaking conditions.",
                  theme = theme_clean()) &
  theme(legend.position = "bottom")
plot_AAVS

ggsave(
  plot = plot_AAVS,
  filename = "Figures/Fig_AAVS.png",
  height = 6,
  width = 10,
  unit = "in",
  scale = .9,
  bg = "white"
)

```
# 04. M1
## /s/ - Expected Posteriors
```{r}
# Generate expected predictions from the posterior
data_posterior_M1s <- model_M1s %>%
  tidybayes::epred_draws(
    newdata = tidyr::expand_grid(
      group = c("Control", "PD"),
      time_point = c("before", "sensors", "after"),
      sex = c("Male", "Female"),
      age = mean(model_M1s$data$age),
      artic_rate = mean(model_M1s$data$artic_rate),
    ),
    re_formula = NA
  ) %>%
  group_by(.draw, group, time_point) %>%
  summarize(.epred = mean(.epred), .groups = "drop") %>%
  dplyr::mutate(
    group = factor(
      group,
      levels = c("Control", "PD"),
      labels = c("Control", "PwPD")
    ),
    #grouping = paste(sex, group, sep = " - "),
    #grouping = factor(grouping,
    #                  levels = c("Male - Control",
    #                             "Male - PwPD",
    #                             "Female - Control",
    #                             "Female - PwPD")),
    time_point = factor(
      time_point,
      levels = c("before", "sensors", "after"),
      labels = c("Before\nSensors", "With\nSensors", "After\nSensors")
    )
  )

```

## /s/ - ME: Timepoint x Group
```{r}
robust_M1s <- rio::import("workingData/data_M1s.RDS")$pairwise %>%
  dplyr::select(contrast, group, robust)

data_meContrasts_M1s <- model_M1s %>%
  emmeans::emmeans(~ time_point | group,
                   epred = TRUE,
                   re_formula = NA,) %>%
  emmeans::contrast(method = "revpairwise") %>%
  gather_emmeans_draws() %>%
  dplyr::filter(contrast != "after - sensors")

# Compute the interaction contrast (difference in contrasts between groups)
interaction_contrast <- model_M1s %>%
  emmeans::emmeans(~ time_point * group, epred = TRUE, re_formula = NA) %>%
  emmeans::contrast(interaction = "revpairwise") %>%
  gather_emmeans_draws() %>%
  dplyr::rename(contrast = time_point_revpairwise,
                group = group_revpairwise) %>%
  dplyr::filter(contrast != "after - sensors")

data_meContrasts_M1s <- base::rbind(data_meContrasts_M1s, interaction_contrast) %>%
  dplyr::mutate(group = case_when(
    group == "PD" ~ "PwPD",
    group == "Control" ~ "Control",
    group == "PD - Control" ~ "PwPD -\nControl"
  )) %>%
  base::merge(., robust_M1s) %>%
  dplyr::mutate(robust = factor(robust,
                                levels = c("not robust",
                                           "robust")))

#bayestestR::p_direction(data_meContrasts_M1s)

```

## /sh/ - Expected Posteriors
```{r}
# Generate expected predictions from the posterior
data_posterior_M1sh <- model_M1sh %>%
  tidybayes::epred_draws(
    newdata = tidyr::expand_grid(
      group = c("Control", "PD"),
      time_point = c("before", "sensors", "after"),
      sex = c("Male", "Female"),
      age = mean(model_M1sh$data$age),
      artic_rate = mean(model_M1sh$data$artic_rate),
    ),
    re_formula = NA
  ) %>%
  group_by(.draw, group, time_point) %>%
  summarize(.epred = mean(.epred), .groups = "drop") %>%
  dplyr::mutate(
    group = factor(
      group,
      levels = c("Control", "PD"),
      labels = c("Control", "PwPD")
    ),
    #grouping = paste(sex, group, sep = " - "),
    #grouping = factor(grouping,
    #                  levels = c("Male - Control",
    #                             "Male - PwPD",
    #                             "Female - Control",
    #                             "Female - PwPD")),
    time_point = factor(
      time_point,
      levels = c("before", "sensors", "after"),
      labels = c("Before\nSensors", "With\nSensors", "After\nSensors")
    )
  )

```

## /sh/ - ME: Timepoint x Group
```{r}
robust_M1sh <- rio::import("workingData/data_M1sh.RDS")$pairwise %>%
  dplyr::select(contrast, group, robust)

data_meContrasts_M1sh <- model_M1sh %>%
  emmeans::emmeans(~ time_point | group,
                   epred = TRUE,
                   re_formula = NA,) %>%
  emmeans::contrast(method = "revpairwise") %>%
  gather_emmeans_draws() %>%
  dplyr::filter(contrast != "after - sensors")

# Compute the interaction contrast (difference in contrasts between groups)
interaction_contrast <- model_M1sh %>%
  emmeans::emmeans(~ time_point * group, epred = TRUE, re_formula = NA) %>%
  emmeans::contrast(interaction = "revpairwise") %>%
  gather_emmeans_draws() %>%
  dplyr::rename(contrast = time_point_revpairwise,
                group = group_revpairwise) %>%
  dplyr::filter(contrast != "after - sensors")

data_meContrasts_M1sh <- base::rbind(data_meContrasts_M1sh, interaction_contrast) %>%
  dplyr::mutate(group = case_when(
    group == "PD" ~ "PwPD",
    group == "Control" ~ "Control",
    group == "PD - Control" ~ "PwPD -\nControl"
  )) %>%
  base::merge(., robust_M1sh) %>%
  dplyr::mutate(robust = factor(robust,
                                levels = c("not robust",
                                           "robust")))

#bayestestR::p_direction(data_meContrasts_M1sh)

```
## Combined
### Expected Posteriors
```{r}
# Generate expected predictions from the posterior
data_posterior_M1 <- rbind(data_posterior_M1s %>%
                             dplyr::mutate(sound = "/s/"),
                           data_posterior_M1sh %>%
                             dplyr::mutate(sound = "/ʃ/"))

plot_grandMean_M1 <- ggplot(data_posterior_M1, 
                                   aes(x = .epred, y = time_point, 
                                       fill = group)) +
  stat_halfeye(alpha = .9) +
  ggokabeito::scale_fill_okabe_ito(order = c(2, 1)) +
  labs(x = "Predicted M1 (kHz)", y = NULL,
       fill = "Group",
       title = "(a) Posterior Predictions",
       subtitle = "Predicted M1 after controlling for\nspeaker age, sex, and articulation rate.") +
  scale_y_discrete(limits = rev) +
  theme_clean() +
  facet_wrap(~sound, ncol = 1) +
  theme(legend.position = "bottom",
        axis.title = element_text(size = textSize_axisTitle),
        plot.title = element_text(size = textSize_plotTitle),
        plot.subtitle = element_text(size = textSize_plotSubtitle))  +
  guides(fill = guide_legend(nrow = 1))
```

### ME: Timepoint x Group
```{r}
data_meContrasts_M1 <- rbind(data_meContrasts_M1s %>%
                             dplyr::mutate(sound = "/s/"),
                           data_meContrasts_M1sh %>%
                             dplyr::mutate(sound = "/ʃ/"))

#bayestestR::p_direction(data_meContrasts_M1)

plot_RQ1_M1 <- ggplot(
  data_meContrasts_M1 %>%
    dplyr::filter(contrast == "sensors - before"),
  aes(x = .value, y = group, fill = robust)
) +
  geom_vline(xintercept = 0, alpha = .3) +
  stat_halfeye(alpha = .9) +
  scale_fill_manual(values = c("#E3B5CF", "#CC79A7"),
                     drop = FALSE) +
  labs(
    x = "Average marginal effect of sensors effects (kHz)",
    y = NULL,
    title = "(b) Research Question 1",
    subtitle = "Sensor effect (With Sensors - Before Sensors)\nper group and the effect contrast between groups.",
    fill = "Robust at 95% HPD Interval & pd"
  ) +
  scale_y_discrete(limits = rev) +
  facet_wrap(~sound, ncol = 1) +
  theme_clean() +
  theme(
    legend.position = "bottom",
    axis.title = element_text(size = textSize_axisTitle),
    plot.title = element_text(size = textSize_plotTitle),
    plot.subtitle = element_text(size = textSize_plotSubtitle)
  )

plot_RQ1_M1

plot_RQ2_M1 <- ggplot(
  data_meContrasts_M1 %>%
    dplyr::filter(contrast == "after - before"),
  aes(x = .value, y = group, fill = robust)
) +
  geom_vline(xintercept = 0, alpha = .3) +
  stat_halfeye(alpha = .9) +
  scale_fill_manual(values = c("#E3B5CF", "#CC79A7"),
                     drop = FALSE) +
  labs(
    x = "Average marginal effect of after-sensor\neffects (kHz)",
    y = NULL,
    title = "(c) Research Question 2",
    subtitle = "After-sensor effect (After Sensors -\nBefore Sensors) per group and the\neffect contrast between groups.",
    fill = "Robust at 95% HPD Interval & pd"
  ) +
  scale_y_discrete(limits = rev) +
  facet_wrap(~sound, ncol = 1) +
  theme_clean() +
  theme(
    legend.position = "bottom",
    axis.title = element_text(size = textSize_axisTitle),
    plot.title = element_text(size = textSize_plotTitle),
    plot.subtitle = element_text(size = textSize_plotSubtitle)
  )

plot_RQ2_M1

# Combined plot
plot_M1 <-  plot_grandMean_M1 + plot_RQ1_M1 + plot_RQ2_M1 +
  patchwork::plot_layout(ncol = 3, heights = c(1), guides = "collect") +
  plot_annotation(title = "Spectral Center of Gravity (M1)", #subtitle = "Predicted intelligibility ratings across group/severity and speaking conditions.",
                  theme = theme_clean()) &
  theme(legend.position = "bottom")
plot_M1

ggsave(
  plot = plot_M1,
  filename = "Figures/Fig_M1.png",
  height = 7,
  width = 10,
  unit = "in",
  scale = .9,
  bg = "white"
)

```

# 05. M2
## /s/ - Expected Posteriors
```{r}
# Generate expected predictions from the posterior
data_posterior_M2s <- model_M2s %>%
  tidybayes::epred_draws(
    newdata = tidyr::expand_grid(
      group = c("Control", "PD"),
      time_point = c("before", "sensors", "after"),
      sex = c("Male", "Female"),
      age = mean(model_M2s$data$age),
      artic_rate = mean(model_M2s$data$artic_rate),
    ),
    re_formula = NA
  ) %>%
  group_by(.draw, group, time_point) %>%
  summarize(.epred = mean(.epred), .groups = "drop") %>%
  dplyr::mutate(
    group = factor(
      group,
      levels = c("Control", "PD"),
      labels = c("Control", "PwPD")
    ),
    #grouping = paste(sex, group, sep = " - "),
    #grouping = factor(grouping,
    #                  levels = c("Male - Control",
    #                             "Male - PwPD",
    #                             "Female - Control",
    #                             "Female - PwPD")),
    time_point = factor(
      time_point,
      levels = c("before", "sensors", "after"),
      labels = c("Before\nSensors", "With\nSensors", "After\nSensors")
    )
  )

```

## /s/ - ME: Timepoint x Group
```{r}
robust_M2s <- rio::import("workingData/data_M2s.RDS")$pairwise %>%
  dplyr::select(contrast, group, robust)

data_meContrasts_M2s <- model_M2s %>%
  emmeans::emmeans(~ time_point | group,
                   epred = TRUE,
                   re_formula = NA,) %>%
  emmeans::contrast(method = "revpairwise") %>%
  gather_emmeans_draws() %>%
  dplyr::filter(contrast != "after - sensors")

# Compute the interaction contrast (difference in contrasts between groups)
interaction_contrast <- model_M2s %>%
  emmeans::emmeans(~ time_point * group, epred = TRUE, re_formula = NA) %>%
  emmeans::contrast(interaction = "revpairwise") %>%
  gather_emmeans_draws() %>%
  dplyr::rename(contrast = time_point_revpairwise,
                group = group_revpairwise) %>%
  dplyr::filter(contrast != "after - sensors")

data_meContrasts_M2s <- base::rbind(data_meContrasts_M2s, interaction_contrast) %>%
  dplyr::mutate(group = case_when(
    group == "PD" ~ "PwPD",
    group == "Control" ~ "Control",
    group == "PD - Control" ~ "PwPD -\nControl"
  )) %>%
  base::merge(., robust_M2s) %>%
  dplyr::mutate(robust = factor(robust,
                                levels = c("not robust",
                                           "robust")))

#bayestestR::p_direction(data_meContrasts_M2s)

```

## /sh/ - Expected Posteriors
```{r}
# Generate expected predictions from the posterior
data_posterior_M2sh <- model_M2sh %>%
  tidybayes::epred_draws(
    newdata = tidyr::expand_grid(
      group = c("Control", "PD"),
      time_point = c("before", "sensors", "after"),
      sex = c("Male", "Female"),
      age = mean(model_M2sh$data$age),
      artic_rate = mean(model_M2sh$data$artic_rate),
    ),
    re_formula = NA
  ) %>%
  group_by(.draw, group, time_point) %>%
  summarize(.epred = mean(.epred), .groups = "drop") %>%
  dplyr::mutate(
    group = factor(
      group,
      levels = c("Control", "PD"),
      labels = c("Control", "PwPD")
    ),
    #grouping = paste(sex, group, sep = " - "),
    #grouping = factor(grouping,
    #                  levels = c("Male - Control",
    #                             "Male - PwPD",
    #                             "Female - Control",
    #                             "Female - PwPD")),
    time_point = factor(
      time_point,
      levels = c("before", "sensors", "after"),
      labels = c("Before\nSensors", "With\nSensors", "After\nSensors")
    )
  )

```

## /sh/ - ME: Timepoint x Group
```{r}
robust_M2sh <- rio::import("workingData/data_M2sh.RDS")$pairwise %>%
  dplyr::select(contrast, group, robust)

data_meContrasts_M2sh <- model_M2sh %>%
  emmeans::emmeans(~ time_point | group,
                   epred = TRUE,
                   re_formula = NA,) %>%
  emmeans::contrast(method = "revpairwise") %>%
  gather_emmeans_draws() %>%
  dplyr::filter(contrast != "after - sensors")

# Compute the interaction contrast (difference in contrasts between groups)
interaction_contrast <- model_M2sh %>%
  emmeans::emmeans(~ time_point * group, epred = TRUE, re_formula = NA) %>%
  emmeans::contrast(interaction = "revpairwise") %>%
  gather_emmeans_draws() %>%
  dplyr::rename(contrast = time_point_revpairwise,
                group = group_revpairwise) %>%
  dplyr::filter(contrast != "after - sensors")

data_meContrasts_M2sh <- base::rbind(data_meContrasts_M2sh, interaction_contrast) %>%
  dplyr::mutate(group = case_when(
    group == "PD" ~ "PwPD",
    group == "Control" ~ "Control",
    group == "PD - Control" ~ "PwPD -\nControl"
  )) %>%
  base::merge(., robust_M2sh) %>%
  dplyr::mutate(robust = factor(robust,
                                levels = c("not robust",
                                           "robust")))

#bayestestR::p_direction(data_meContrasts_M2sh)

```
## Combined
### Expected Posteriors
```{r}
# Generate expected predictions from the posterior
data_posterior_M2 <- rbind(data_posterior_M2s %>%
                             dplyr::mutate(sound = "/s/"),
                           data_posterior_M2sh %>%
                             dplyr::mutate(sound = "/ʃ/"))

plot_grandMean_M2 <- ggplot(data_posterior_M2, 
                                   aes(x = .epred, y = time_point, 
                                       fill = group)) +
  stat_halfeye(alpha = .9) +
  ggokabeito::scale_fill_okabe_ito(order = c(2, 1)) +
  labs(x = "Predicted M2 (kHz)", y = NULL,
       fill = "Group",
       title = "(a) Posterior Predictions",
       subtitle = "Predicted M2 after controlling for\nspeaker age, sex, and articulation rate.") +
  scale_y_discrete(limits = rev) +
  theme_clean() +
  facet_wrap(~sound, ncol = 1) +
  theme(legend.position = "bottom",
        axis.title = element_text(size = textSize_axisTitle),
        plot.title = element_text(size = textSize_plotTitle),
        plot.subtitle = element_text(size = textSize_plotSubtitle))  +
  guides(fill = guide_legend(nrow = 1))
```

### ME: Timepoint x Group
```{r}
data_meContrasts_M2 <- rbind(data_meContrasts_M2s %>%
                             dplyr::mutate(sound = "/s/"),
                           data_meContrasts_M2sh %>%
                             dplyr::mutate(sound = "/ʃ/"))

#bayestestR::p_direction(data_meContrasts_M2)

plot_RQ1_M2 <- ggplot(
  data_meContrasts_M2 %>%
    dplyr::filter(contrast == "sensors - before"),
  aes(x = .value, y = group, fill = robust)
) +
  geom_vline(xintercept = 0, alpha = .3) +
  stat_halfeye(alpha = .9) +
  scale_fill_manual(values = c("#E3B5CF", "#CC79A7"),
                     drop = FALSE) +
  labs(
    x = "Average marginal effect of sensors effects (kHz)",
    y = NULL,
    title = "(b) Research Question 1",
    subtitle = "Sensor effect (With Sensors - Before Sensors)\nper group and the effect contrast between groups.",
    fill = "Robust at 95% HPD Interval & pd"
  ) +
  scale_y_discrete(limits = rev) +
  facet_wrap(~sound, ncol = 1) +
  theme_clean() +
  theme(
    legend.position = "bottom",
    axis.title = element_text(size = textSize_axisTitle),
    plot.title = element_text(size = textSize_plotTitle),
    plot.subtitle = element_text(size = textSize_plotSubtitle)
  )

plot_RQ1_M2

plot_RQ2_M2 <- ggplot(
  data_meContrasts_M2 %>%
    dplyr::filter(contrast == "after - before"),
  aes(x = .value, y = group, fill = robust)
) +
  geom_vline(xintercept = 0, alpha = .3) +
  stat_halfeye(alpha = .9) +
  scale_fill_manual(values = c("#E3B5CF", "#CC79A7"),
                     drop = FALSE) +
  labs(
    x = "Average marginal effect of after-sensor\neffects (kHz)",
    y = NULL,
    title = "(c) Research Question 2",
    subtitle = "After-sensor effect (After Sensors -\nBefore Sensors) per group and the\neffect contrast between groups.",
    fill = "Robust at 95% HPD Interval & pd"
  ) +
  scale_y_discrete(limits = rev) +
  facet_wrap(~sound, ncol = 1) +
  theme_clean() +
  theme(
    legend.position = "bottom",
    axis.title = element_text(size = textSize_axisTitle),
    plot.title = element_text(size = textSize_plotTitle),
    plot.subtitle = element_text(size = textSize_plotSubtitle)
  )

plot_RQ2_M2

# Combined plot
plot_M2 <-  plot_grandMean_M2 + plot_RQ1_M2 + plot_RQ2_M2 +
  patchwork::plot_layout(ncol = 3, heights = c(1), guides = "collect") +
  plot_annotation(title = "Spectral Standard Deviation (M2)", #subtitle = "Predicted intelligibility ratings across group/severity and speaking conditions.",
                  theme = theme_clean()) &
  theme(legend.position = "bottom")
plot_M2

ggsave(
  plot = plot_M2,
  filename = "Figures/Fig_M2.png",
  height = 7,
  width = 10,
  unit = "in",
  scale = .9,
  bg = "white"
)

```

# 06. Intelligibility
## Expected Posteriors
```{r}
epsilon <- 1e-5
# Generate expected predictions from the posterior
data_posterior_Int <- model_Int %>%
  tidybayes::epred_draws(
    newdata = tidyr::expand_grid(
      group = c("Control", "PD"),
      time_point = c("before", "sensors", "after"),
      sex = c("Male", "Female"),
      age = mean(model_Int$data$age), # 66.91 yo
      artic_rate = mean(model_Int$data$artic_rate), # 4.85 syl/s
      trial_number = mean(model_Int$data$trial_number) # trial 9
    ),
    re_formula = NA
  ) %>%
  group_by(.draw, group, time_point) %>%
  summarize(.epred = mean(.epred), .groups = "drop") %>%
  dplyr::mutate(
    group = factor(
      group,
      levels = c("Control", "PD"),
      labels = c("Control", "PwPD")
    ),
    #grouping = paste(sex, group, sep = " - "),
    #grouping = factor(grouping,
    #                  levels = c("Male - Control",
    #                             "Male - PwPD",
    #                             "Female - Control",
    #                             "Female - PwPD")),
    time_point = factor(
      time_point,
      levels = c("before", "sensors", "after"),
      labels = c("Before\nSensors", "With\nSensors", "After\nSensors")
    ),
    .epred = (.epred - epsilon) / (1 - 2 * epsilon),
    # Step 1 & 2: Reverse the offset and scaling
    .epred = .epred * nrow(.) / ((nrow(.) - 1) + .5),
    .epred = .epred * 100 # to turn it back to a scale of 0 - 100
  )

plot_grandMean_Int <- ggplot(data_posterior_Int, 
                                   aes(x = .epred, y = time_point, 
                                       fill = group)) +
  stat_halfeye(alpha = .9) +
  ggokabeito::scale_fill_okabe_ito(order = c(2, 1)) +
  labs(x = "Predicted intelligibility rating (%)", y = NULL,
       fill = "Group",
       title = "(a) Posterior Predictions",
       subtitle = "Predicted intelligibility rating after controlling\nfor speaker age, sex, articulation rate,\nand trial number.") +
  scale_y_discrete(limits = rev) +
  coord_cartesian(xlim = c(72,100)) +
  theme_clean() +
  theme(legend.position = "bottom",
        axis.title = element_text(size = textSize_axisTitle),
        plot.title = element_text(size = textSize_plotTitle),
        plot.subtitle = element_text(size = textSize_plotSubtitle),
        #panel.border = element_rect(color = "grey", fill = NA)
        ) +
  guides(fill = guide_legend(nrow = 1))
```

## ME: Timepoint x Group
```{r}
robust_Int <- rio::import("workingData/data_Int.RDS")$pairwise %>%
  dplyr::select(contrast, group, robust)

epsilon <- 1e-5
data_meContrasts_Int <- model_Int %>%
  emmeans::emmeans(~ time_point | group,
                   epred = TRUE,
                   re_formula = NA,) %>%
  emmeans::contrast(method = "revpairwise") %>%
  gather_emmeans_draws() %>%
  dplyr::mutate(
    .value = (.value - epsilon) / (1 - 2 * epsilon),
    # Step 1 & 2: Reverse the offset and scaling
    .value = .value * nrow(.) / ((nrow(.) - 1) + .5),
    .value = .value * 100
  ) %>%
  dplyr::filter(contrast != "after - sensors")

# Compute the interaction contrast (difference in contrasts between groups)
interaction_contrast <- model_Int %>%
  emmeans::emmeans(~ time_point * group, epred = TRUE, re_formula = NA) %>%
  emmeans::contrast(interaction = "revpairwise") %>%
  gather_emmeans_draws() %>%
  dplyr::mutate(
    .value = (.value - epsilon) / (1 - 2 * epsilon),
    # Step 1 & 2: Reverse the offset and scaling
    .value = .value * nrow(.) / ((nrow(.) - 1) + .5),
    .value = .value * 100
  ) %>%
  dplyr::rename(contrast = time_point_revpairwise,
                group = group_revpairwise) %>%
  dplyr::filter(contrast != "after - sensors")

data_meContrasts_Int <- base::rbind(data_meContrasts_Int, interaction_contrast) %>%
  dplyr::mutate(group = case_when(
    group == "PD" ~ "PwPD",
    group == "Control" ~ "Control",
    group == "PD - Control" ~ "PwPD -\nControl"
  )) %>%
  base::merge(., robust_Int) %>%
  dplyr::mutate(robust = factor(robust,
                                levels = c("not robust",
                                           "robust")))

plot_RQ1_Int <- ggplot(
  data_meContrasts_Int %>%
    dplyr::filter(contrast == "sensors - before"),
  aes(x = .value, y = group, fill = robust)
) +
  geom_vline(xintercept = 0, alpha = .3) +
  stat_halfeye(alpha = .9) +
  scale_fill_manual(values = c("#E3B5CF", "#CC79A7"),
                     drop = FALSE) +
  # Text annotation for the Control and PwPD distributions
  annotate(
    'text',
    x = -.13*100, # Play around with the coordinates until you're satisfied
    y = 3.3,
    label = "Both Control and PwPD\nwere robustly less intelligbile\nwith EMA sensors on...",
    hjust = 0,
    size = 2,
    alpha = .8,
    color = "black"
  ) +
  # Arrow to the Control distribution
  annotate(
    'curve',
    x = -.095*100, # Play around with the coordinates until you're satisfied
    y = 3.1,
    xend = -.03*100,
    yend = 2.96,
    linewidth = .4,
    curvature = 0.2,
    arrow = arrow(length = unit(0.1, 'cm'), type = "closed"),
    alpha = 1,
    color = "darkgrey"
  ) +
  # Arrow to the PwPD distribution
  annotate(
    'curve',
    x = -.096*100, # Play around with the coordinates until you're satisfied
    y = 3.1,
    xend = -.065*100,
    yend = 2.3,
    linewidth = .4,
    curvature = 0.2,
    arrow = arrow(length = unit(0.1, 'cm'), type = "closed"),
    alpha = 1,
    color = "darkgrey"
  ) +
  # Text for the contrast distribution
  annotate(
    'text',
    x = -.07*100, # Play around with the coordinates until you're satisfied
    y = 0.73,
    label = "... but these effects\nwere robustly different\nbetween the groups.",
    hjust = 1,
    size = 2,
    alpha = .8,
    color = "black"
  ) +
    # Arrow to the contrast distribution
  annotate(
    'curve',
    x = -.065*100, # Play around with the coordinates until you're satisfied
    y = 0.73,
    xend = -.045*100,
    yend = .95,
    linewidth = .4,
    curvature = 0.2,
    arrow = arrow(length = unit(0.1, 'cm'), type = "closed"),
    alpha = 1,
    color = "darkgrey"
  ) +
  labs(
    x = "Average marginal effect of sensors effects (%)",
    y = NULL,
    title = "(b) Research Question 1",
    subtitle = "Sensor effect (With Sensors - Before Sensors)\nper group and the effect contrast between groups.",
    fill = "Robust at 95% HPD Interval & pd"
  ) +
  scale_y_discrete(limits = rev) +
  theme_clean() +
  theme(
    legend.position = "bottom",
    axis.title = element_text(size = textSize_axisTitle),
    plot.title = element_text(size = textSize_plotTitle),
    plot.subtitle = element_text(size = textSize_plotSubtitle)
  )

plot_RQ1_Int

plot_RQ2_Int <- ggplot(
  data_meContrasts_Int %>%
    dplyr::filter(contrast == "after - before"),
    aes(x = .value, y = group, fill = robust)
) +
  geom_vline(xintercept = 0, alpha = .3) +
  stat_halfeye(alpha = .9) +
  scale_fill_manual(values = c("#E3B5CF", "#CC79A7"),
                     drop = FALSE) +
  labs(
    x = "Average marginal effect of after-sensor\neffects (%)",
    y = NULL,
    title = "(c) Research Question 2",
    subtitle = "After-sensor effect (After Sensors -\nBefore Sensors) per group and the\neffect contrast between groups.",
    fill = "Robust at 95% HPD Interval & pd"
  ) +
  scale_y_discrete(limits = rev) +
  theme_clean() +
  theme(
    legend.position = "bottom",
    axis.title = element_text(size = textSize_axisTitle),
    plot.title = element_text(size = textSize_plotTitle),
    plot.subtitle = element_text(size = textSize_plotSubtitle)
  )

plot_RQ2_Int

# Combined plot
plot_Int <-  plot_grandMean_Int + plot_RQ1_Int + plot_RQ2_Int +
  patchwork::plot_layout(ncol = 3, heights = c(1), guides = "collect") +
  plot_annotation(title = "Intelligibility", #subtitle = "Predicted intelligibility ratings across group/severity and speaking conditions.",
                  theme = theme_clean()) &
  theme(legend.position = "bottom")
plot_Int

ggsave(
  plot = plot_Int,
  filename = "Figures/Fig_Int.png",
  height = 6,
  width = 10,
  unit = "in",
  scale = .9,
  bg = "white"
)

```


# 07. Naturalness
## Expected Posteriors
```{r}
epsilon <- 1e-5
# Generate expected predictions from the posterior
data_posterior_Nat <- model_Nat %>%
  tidybayes::epred_draws(
    newdata = tidyr::expand_grid(
      group = c("Control", "PD"),
      time_point = c("before", "sensors", "after"),
      sex = c("Male", "Female"),
      age = mean(model_Nat$data$age), # 66.91 yo
      artic_rate = mean(model_Nat$data$artic_rate), # 4.85 syl/s
      trial_number = mean(model_Nat$data$trial_number) # trial 9
    ),
    re_formula = NA
  ) %>%
  group_by(.draw, group, time_point) %>%
  summarize(.epred = mean(.epred), .groups = "drop") %>%
  dplyr::mutate(
    group = factor(
      group,
      levels = c("Control", "PD"),
      labels = c("Control", "PwPD")
    ),
    #grouping = paste(sex, group, sep = " - "),
    #grouping = factor(grouping,
    #                  levels = c("Male - Control",
    #                             "Male - PwPD",
    #                             "Female - Control",
    #                             "Female - PwPD")),
    time_point = factor(
      time_point,
      levels = c("before", "sensors", "after"),
      labels = c("Before\nSensors", "With\nSensors", "After\nSensors")
    ),
    .epred = (.epred - epsilon) / (1 - 2 * epsilon),
    # Step 1 & 2: Reverse the offset and scaling
    .epred = .epred * nrow(.) / ((nrow(.) - 1) + .5),
    .epred = .epred * 100
  )

plot_grandMean_Nat <- ggplot(data_posterior_Nat, 
                                   aes(x = .epred, y = time_point, 
                                       fill = group)) +
  stat_halfeye(alpha = .9) +
  ggokabeito::scale_fill_okabe_ito(order = c(2, 1)) +
  labs(x = "Predicted naturalness rating (%)", y = NULL,
       fill = "Group",
       title = "(a) Posterior Predictions",
       subtitle = "Predicted naturalness rating after controlling\nfor speaker age, sex, articulation rate,\nand trial number.") +
  scale_y_discrete(limits = rev) +
  coord_cartesian(xlim = c(0,100)) +
  theme_clean() +
  theme(legend.position = "bottom",
        axis.title = element_text(size = textSize_axisTitle),
        plot.title = element_text(size = textSize_plotTitle),
        plot.subtitle = element_text(size = textSize_plotSubtitle))  +
  guides(fill = guide_legend(nrow = 1))
```

## ME: Timepoint x Group
```{r}
robust_Nat <- rio::import("workingData/data_Nat.RDS")$pairwise %>%
  dplyr::select(contrast, group, robust)

epsilon <- 1e-5
data_meContrasts_Nat <- model_Nat %>%
  emmeans::emmeans(~ time_point | group,
                   epred = TRUE,
                   re_formula = NA,) %>%
  emmeans::contrast(method = "revpairwise") %>%
  gather_emmeans_draws() %>%
  dplyr::mutate(
    .value = (.value - epsilon) / (1 - 2 * epsilon),
    # Step 1 & 2: Reverse the offset and scaling
    .value = .value * nrow(.) / ((nrow(.) - 1) + .5),
    .value = .value * 100
  ) %>%
  dplyr::filter(contrast != "after - sensors")

# Compute the interaction contrast (difference in contrasts between groups)
interaction_contrast <- model_Nat %>%
  emmeans::emmeans(~ time_point * group, epred = TRUE, re_formula = NA) %>%
  emmeans::contrast(interaction = "revpairwise") %>%
  gather_emmeans_draws() %>%
  dplyr::mutate(
    .value = (.value - epsilon) / (1 - 2 * epsilon),
    # Step 1 & 2: Reverse the offset and scaling
    .value = .value * nrow(.) / ((nrow(.) - 1) + .5),
    .value = .value * 100
  ) %>%
  dplyr::rename(contrast = time_point_revpairwise,
                group = group_revpairwise) %>%
  dplyr::filter(contrast != "after - sensors")

data_meContrasts_Nat <- base::rbind(data_meContrasts_Nat, interaction_contrast)  %>%
  dplyr::mutate(group = case_when(
    group == "PD" ~ "PwPD",
    group == "Control" ~ "Control",
    group == "PD - Control" ~ "PwPD -\nControl"
  )) %>%
  base::merge(., robust_Nat) %>%
  dplyr::mutate(robust = factor(robust,
                                levels = c("not robust",
                                           "robust")))

#bayestestR::p_direction(data_meContrasts_Nat)

plot_RQ1_Nat <- ggplot(
  data_meContrasts_Nat %>%
    dplyr::filter(contrast == "sensors - before"),
    aes(x = .value, y = group, fill = robust)
) +
  geom_vline(xintercept = 0, alpha = .3) +
  stat_halfeye(alpha = .9) +
  scale_fill_manual(values = c("#E3B5CF", "#CC79A7"),
                     drop = FALSE) +
  labs(
    x = "Average marginal effect of sensors effects (%)",
    y = NULL,
    title = "(b) Research Question 1",
    subtitle = "Sensor effect (With Sensors - Before Sensors)\nper group and the effect contrast between groups.",
    fill = "Robust at 95% HPD Interval & pd"
  ) +
  scale_y_discrete(limits = rev) +
  theme_clean() +
  theme(
    legend.position = "bottom",
    axis.title = element_text(size = textSize_axisTitle),
    plot.title = element_text(size = textSize_plotTitle),
    plot.subtitle = element_text(size = textSize_plotSubtitle)
  )

plot_RQ1_Nat

plot_RQ2_Nat <- ggplot(
  data_meContrasts_Nat %>%
    dplyr::filter(contrast == "after - before"),
    aes(x = .value, y = group, fill = robust)
) +
  geom_vline(xintercept = 0, alpha = .3) +
  stat_halfeye(alpha = .9) +
  scale_fill_manual(values = c("#E3B5CF", "#CC79A7"),
                     drop = FALSE) +
  labs(
    x = "Average marginal effect of after-sensors\neffects (%)",
    y = NULL,
    title = "(c) Research Question 2",
    subtitle = "After-sensor effect (After Sensors -\nBefore Sensors) per group and the\neffect contrast between groups.",
    fill = "Robust at 95% HPD Interval & pd"
  ) +
  scale_y_discrete(limits = rev) +
  theme_clean() +
  theme(
    legend.position = "bottom",
    axis.title = element_text(size = textSize_axisTitle),
    plot.title = element_text(size = textSize_plotTitle),
    plot.subtitle = element_text(size = textSize_plotSubtitle)
  )

plot_RQ2_Nat

# Combined plot
plot_Nat <-  plot_grandMean_Nat + plot_RQ1_Nat + plot_RQ2_Nat +
  patchwork::plot_layout(ncol = 3,
                         heights = c(1),
                         guides = "collect") +
  plot_annotation(title = "Naturalness",
                  theme = theme_clean()) &
  theme(legend.position = "bottom")
plot_Nat

ggsave(
  plot = plot_Nat,
  filename = "Figures/Fig_Nat.png",
  height = 6,
  width = 10,
  unit = "in",
  scale = .9,
  bg = "white"
)

```
# S01. Individual Variability
```{r}
workingData_articRate <- base::readRDS(file = "workingData/data_articRate.RDS")
workingData_AAVS <- base::readRDS(file = "workingData/data_AAVS.RDS")
workingData_M1s <- base::readRDS(file = "workingData/data_M1s.RDS")
workingData_M1sh <- base::readRDS(file = "workingData/data_M1sh.RDS")
workingData_M2s <- base::readRDS(file = "workingData/data_M2s.RDS")
workingData_M2sh <- base::readRDS(file = "workingData/data_M2sh.RDS")
workingData_Int <- base::readRDS(file = "workingData/data_Int.RDS")
workingData_Nat <- base::readRDS(file = "workingData/data_Nat.RDS")

allData <- bind_rows(
  workingData_articRate$modelData %>%
    dplyr::mutate(measure = "Articulation Rate") %>%
    dplyr::rename(value = articRate),
  
  workingData_AAVS$modelData %>%
    dplyr::mutate(measure = "AAVS") %>%
    dplyr::rename(value = AAVS),
  
  workingData_M1s$modelData %>%
    dplyr::mutate(measure = "M1 for /s/") %>%
    dplyr::rename(value = M1s),
  
  workingData_M2s$modelData %>%
    dplyr::mutate(measure = "M2 for /s/") %>%
    dplyr::rename(value = M2s),
  
  workingData_M1sh$modelData %>%
    dplyr::mutate(measure = "M1 for /ʃ/") %>%
    dplyr::rename(value = M1sh),
  
  workingData_M2sh$modelData %>%
    dplyr::mutate(measure = "M2 for /ʃ/") %>%
    dplyr::rename(value = M2sh),
  
  workingData_Int$modelData %>%
    dplyr::mutate(measure = "Intelligibility",
                  Int = Int*100) %>%
    dplyr::rename(value = Int),
  
  workingData_Nat$modelData %>%
    dplyr::mutate(measure = "Naturalness",
                  Nat = Nat*100) %>%
    dplyr::rename(value = Nat)
) %>%
  dplyr::mutate(time_point = factor(time_point,
                                    levels = c("before",
                                               "sensors",
                                               "after"),
                                    labels = c("Before\nSensors",
                                               "With\nSensors",
                                               "After\nSensors")),
                measure = factor(measure,
                                 levels = c("Articulation Rate",
                                            "AAVS",
                                            "M1 for /s/",
                                            "M2 for /s/",
                                            "M1 for /ʃ/",
                                            "M2 for /ʃ/",
                                            "Intelligibility",
                                            "Naturalness"),
                                 labels = c("Articulation Rate (syl/s)",
                                            "AAVS (mel²)",
                                            "M1 for /s/ (kHz)",
                                            "M2 for /s/ (kHz)",
                                            "M1 for /ʃ/ (kHz)",
                                            "M2 for /ʃ/ (kHz)",
                                            "Intelligibility (%)",
                                            "Naturalness (%)")),
                group = factor(group,
                               levels = c("Control",
                                          "PD"),
                               labels = c("Control",
                                          "PwPD")),
                grouping = paste(sex, group, sep = " - "),
                grouping = factor(grouping,
                      levels = c("Male - Control",
                                 "Male - PwPD",
                                 "Female - Control",
                                 "Female - PwPD"))) %>%
  dplyr::group_by(measure, speaker_id, group, sex, grouping, age, time_point) %>%
  dplyr::summarise(value = mean(value)) %>%
  dplyr::ungroup()

plotData <- bind_rows(
  allData %>%
    dplyr::mutate(plot = "All Data"),
  allData %>%
    dplyr::filter(time_point != "After\nSensors") %>%
    dplyr::mutate(plot = "Sensor Effects"),
  allData %>%
    dplyr::filter(time_point != "With\nSensors") %>%
    dplyr::mutate(plot = "After-Sensor Effects"),
) %>%
  dplyr::mutate(plot = factor(plot,
                              levels = c("All Data",
                                         "Sensor Effects",
                                         "After-Sensor Effects"),
                              labels = c("All Data",
                                         "Sensor Effects",
                                         "After-Sensor\nEffects"))) %>%
  dplyr::filter(plot != "All Data")

plot_rawData_sensorEffects <- plotData %>%
  dplyr::filter(plot == "Sensor Effects") %>%
  ggplot() +
  aes(x = time_point, y = value, color = group) +
  geom_line(aes(group = speaker_id), alpha = .3) +
  geom_line(
    data = plotData %>%
      dplyr::filter(plot == "Sensor Effects") %>%
      dplyr::group_by(measure, group, sex, time_point, plot) %>%
      dplyr::summarise(value = mean(value)),
    aes(group = group),
    alpha = .8,
    linewidth = 1.5
  ) +
  #geom_point(aes(shape = sex)) +
  ggokabeito::scale_color_okabe_ito(order = c(2,1)) +
  facet_grid(measure ~ sex, scales = "free", switch = "y") +
  labs(x = NULL,
       y = NULL,
       color = "Group",
       shape = "Sex",
       title = "Sensor Effects") +
  scale_x_discrete(expand=expansion(c(.35,.35))) +
  theme_clean() &
  theme(panel.border = element_rect(fill = NA, color = "black"),
        strip.background = element_rect(fill = "white", color = NA),
        strip.placement = "outside",
        strip.text.y.left = element_text(angle = 0, face="plain", hjust = 1),)
plot_rawData_sensorEffects

plot_rawData_afterSensorEffects <- plotData %>%
  dplyr::filter(plot == "After-Sensor\nEffects") %>%
  ggplot() +
  aes(x = time_point, y = value, color = group) +
  geom_line(aes(group = speaker_id), alpha = .3) +
  geom_line(
    data = plotData %>%
      dplyr::filter(plot == "After-Sensor\nEffects") %>%
      dplyr::group_by(measure, group, sex, time_point, plot) %>%
      dplyr::summarise(value = mean(value)),
    aes(group = group),
    alpha = .8,
    linewidth = 1.5
  ) +
  #geom_point(aes(shape = sex)) +
  ggokabeito::scale_color_okabe_ito(order = c(2,1)) +
  facet_grid(measure ~ sex, scales = "free") +
  labs(x = NULL,
       y = NULL,
       color = "Group",
       shape = "Sex",
       title = "After-Sensor Effects") +
  scale_x_discrete(expand=expansion(c(.35,.35))) +
  theme_clean() &
  theme(panel.border = element_rect(fill = NA, color = "black"),
        #strip.background = element_rect(fill = "white", color = NA),
        strip.placement = "outside",
        #strip.text.y.left = element_text(angle = 0, face="plain", hjust = 1),
        strip.background = element_blank(),
        strip.text.y. = element_blank())
plot_rawData_afterSensorEffects

plot_rawData <- plot_rawData_sensorEffects + plot_rawData_afterSensorEffects +
  patchwork::plot_layout(ncol = 2, #heights = c(1),
                         guides = "collect") +
  plot_annotation(title = "Raw Data", #subtitle = "Predicted intelligibility ratings across group/severity and speaking conditions.",
                  theme = theme_clean()) &
  theme(
    legend.position = "right",
    strip.background.right = element_blank(),
    strip.text.y.right = element_blank()
  )

ggsave(
  plot = plot_rawData,
  filename = "Figures/SupFig_rawData.png",
  height = 10,
  width = 9,
  unit = "in",
  scale = .9,
  bg = "white"
)
```

